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从 零 开 始 构 建 一 全 计算机 ， 原 来 一 切 如 此 奇妙 | 


关于 作者 : 

Charles Petzold 是 Windows 编 程 界 的 一 位 大 师 ， 当 今世 界 顶 级 
技术 作家 。1994 年 5 月 ，Petzold 作 为 仅 有 的 七 个 人 之 一 ( 并 且 是 唯一 
的 作家 ) 被 《视窗 杂志 》 和 Microsoft 公 司 联合 授予 Windows Pioneer 
奖 ， 以 表彰 他 对 Microsoft Windows 所 做 出 的 贡献 。 


Petzold 从 1984 年 开始 编写 个 人 计算 机 程序 ， 从 1985 年 开始 编 
写 Microsoft Windows 程 序 。1986 年 他 在 Microsoft Systems Journal 
的 12 月 号 上 发 表 了 第 一 篇 关于 Windows 程 序 设 计 的 论文 。 


从 1986 年 到 1995 年 ，Petzold 为 PC _ Magazine 撰写 专栏 文章 ， 向 
读者 介绍 Windows 和 OS/2 程 序 设计 等 方面 的 知识 。 直 到 今天 他 依然 保持 着 Windows 
GDI 程 序 设计 首席 技术 作家 的 地 位 。 其 大 作 Programming Windows ( Windows 程 序 设计 ) 
是 尽 人 皆 知 的 Windows 编 程 经 典 ， 曾 深 深 地 影响 过 一 代 程序 员 ， 该 书目 前 已 出 至 第 5 版 。 
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内 容 简 介 

这 是 一 本 讲述 计算 机 工作 原理 的 书 。 不 过 ， 你 千 万 不 要 因为 “工作 原理 ”之 类 的 字眼 就 武 
断 地 认为 , 它 是 星 涩 而 难 懂 的 。 作 者 用 丰富 的 想象 和 清晰 的 笔墨 将 看 似 繁 杂 的 理论 阐述 得 通俗 
易 履 ,你 丝毫 不 会 感到 枯燥 和 生硬 。 更 重要 的 是 ， 你 会 因此 而 获得 对 计算 机 工作 原理 较 深刻 的 
理解 。 这 种 理解 不 是 抽象 层面 上 的 , 而 是 具有 一 定 深度 的 , 这 种 深度 甚至 不 撑 于 “电气 工程 师 ” 
和 “程序 员 ” 的 理解 。 

不 管 你 是 计算 机 高 手 , 还 是 对 这 个 神奇 的 机 器 充满 敬 明 之 心 的 菜鸟 ,都 不 妨 翻阅 一 下 本 书 ， 
读 一 读 大 师 的 经 典 作品 ， 必 然 会 有 收获 。 


Original English language Edition ©2000 by Charles Petzold. All rights reserved. Chinese edition 
published by arrangement with the original publisher, Microsoft Corporation, Redmond, Washington, 
U.S.A. 


本 书 中 文 简体 版 专 有 出 版 权 由 Microsoft Corporation 授予 电子 工业 出 版 社 ， 专 有 出 版 权 受 
法 律 保护 。 
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3，a， 一 种 在 信息 传输 过 程 中 用 来 表述 字母 或 数字 的 信号 系统 。 
b， 由 被 赋予 了 一 定 主观 意义 的 符号 、 字 母 以 及 单词 所 组 成 的 系 
统 ， 该 系统 可 用 于 传输 需要 保密 的 或 简短 的 信息 。 
4. 一 种 由 若干 符号 和 规则 组 成 的 系统 ， 用 来 向 计算 机 表述 指令 。 
一 一 摘自 《美国 传统 英语 词典 》 


code (kod) ... 


3. a. A system of signals used to represent letters or numbers in 
transmitting messages. 


b. A system of symbols, letters, or words given certain arbitrary 
meanings, used for transmitting messages requiring secrecy or brevity. 


4. A system of symbols and rules used to represent instructions to a 
computer... 
一 The American Heritage Dictionary of the English Language 


《道德 经 》 有 云 : 大 方 无 阳 ， 大 象 无 形 ， 也 就 是 老子 所 说 “ 道 ”的 至 高 境界 。 世 界 上 
最 恢宏 、 壮 丽 的 气派 和 境界 ,往往 并 不 拘泥 于 一 定 的 事物 和 格局 ， 而 是 表现 出 “气象 万 
干 ”的 面貌 和 场景 ， 科 学 知识 的 论述 也 是 如 此 。 科 学 不 一 定 等 同 于 隐 涩 和 深奥 ， 最 复杂 
的 理论 也 可 用 最 简单 的 方式 描述 。 这 就 是 普遍 存在 于 现实 世界 的 辩证 的 、 朴 素 的 唯物 主 
义 精 神 。 

我 想 Charles Petzold 就 是 这 样 一 位 智者 。 作 为 Windows 编程 界 开 创 者 之 一 和 世界 顶 
级 的 技术 专家 ， 他 在 Windows 编程 方面 著述 丰富 ， 在 基础 计算 机 理论 书籍 方面 也 取得 了 
卓 尔 不 凡 的 成 就 。 他 善 用 丰富 的 想象 和 清晰 的 笔墨 将 看 似 繁杂 的 理论 描述 得 生动 、 简 单 ， 
使 读者 不 会 感到 枯燥 和 生硬 。 尤 其 这 本 畅销 多 年 、 经 久 不 衰 的 《编码 一 -隐匿 在 计算 机 软 
硬件 背后 的 语言 》( Code: The Hidden Language of Computer Hardware and Sofiware ) 更 是 
化 腐朽 为 神奇 ， 改 隆 涩 为 通俗 之 杰作 。 即 使 读者 不 是 计算 机 专业 的 人 士 ， 在 Petzold 笔 
墨 的 引导 之 下 ， 也 能 够 轻松 阅读 该 书 。 书 中 使 用 像 电线 、 电 灯泡 、 触 发 器 等 这 些 非常 党 
见 的 零件 ， 拼 拼接 接 ， 最 后 令 人 惊异 地 建造 了 一 台电 子 计算 机 。 读 者 在 阅读 过 程 中 ， 循 
序 渐 进 地 学 习 有 关 计 算 机 系统 基础 和 构造 的 知识 ， 作 者 的 奇 思 妙 想 和 妙趣 横生 的 讲述 方 
式 不 得 不 令 人 赞叹 。 

透 过 现象 进而 探索 本 质 可 以 发 现 新 事物 ; 将 复杂 的 事物 简单 化 ， 可 以 发 现 解 决 问题 
的 新 方法 。 作 者 将 那些 看 似 复杂 的 理论 转换 成 我 们 熟悉 的 诸多 景象 ， 使 读者 不 由 自主 地 
跟随 他 的 思路 打造 这 台 只 有 电线 、 电 灯泡 和 触发 器 组 构成 的 庞大 的 计算 机 系统 。 


IV 


我 阅读 了 本 书 的 译 稿 ， 并 非常 欣喜 地 将 其 推荐 给 每 一 位 读者 ， 我 相信 读者 都 能 获 益 
良 多 。 本 书 的 译 者 做 了 一 件 非 常 有 意义 的 事情 ， 将 一 部 优秀 的 作品 介绍 给 读者 。 他 们 严 
说 的 工作 将 本 书 诠释 得 非常 出 色 ， 使 之 在 不 丧失 原作 风采 的 基础 上 更 贴 合 中 国 读者 的 习 
惯 。 

最 后 , 我 还 是 想 将 《道德 经 》 上 的 两 句 话 来 送 给 各 位 读者 一 一 “为 学 日 益 , 为 道 日 损 ， 
损 之 又 损 ， 以 至 于 无 为 ， 无 为 而 无 不 为 "。 启 心 希望 各 位 读者 有 朝 一 日 都 能 够 在 学 问 上 到 
达 无 为 而 治 的 境界 。 


丁 秋 林 教授 ， 博 士 生 导师 ， 南 京 航空 航天 大 学 信息 科学 与 技术 学 院 和 机 电工 程 学 院 资深 教 
授 。 英 国 和 皇家 航空 学 会 高 级 会 员 、 英 国 剑桥 世界 名 人 录 传 记 人 物 (IBC Cambridge the 28th 
Edition) 、 美 国 世界 名 人 录 传 记 人 物 (Who’s Who in the World the 16th Edition) 、 国 际 高 级 制 
造 技术 杂志 编辑 部 成 员 (Springer) 。 
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在 想到 要 给 《编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 )( Code: The Hidden Language 
of Computer Hardware and Sofiware ) 写 一 篇 序言 的 时 候 , 内心 就 不 由 得 激动 起 来 。 能够 翻 
译 这 部 经 典 之 作 实 属 吾 辈 之 荣华。 早 在 一 年 多 之 前 ， 电 子 工业 出 版 社 的 编辑 跟 我 提 到 这 
本 书 的 翻译 之 事 时 ， 我 便 有 颇 大 的 兴趣 。 一 是 由 于 该 书 作 者 Charles Petzold 的 鼎鼎 大 名 ， 
二 是 由 于 该 部 作品 本 身 内 容 之 不 凡 。 


作为 Windows 编程 界 的 一 位 传奇 人 物 ，Charles Petzold 早 在 1994 年 就 作为 仅 有 的 七 
人 之 一 (并 且 是 唯一 的 作家 ) 被 《视窗 杂志 》 和 Microsoft 公司 授予 Windows Pioneer 奖 。 
而 作为 一 名 世界 顶级 的 技术 作家 , 他 的 大 作 Programming Windows 则 是 尽 和 人缘 知 的 Win32 
API 编程 经 典 ， 是 学 习 Windows 编程 的 必 读 之 作 。 令 我 们 欣喜 的 是 ， 除 了 Windows 程序 
设计 方面 的 著作 ，Petzold 还 撰写 了 这 部 讲述 计算 机 工作 原理 的 书籍 ， 而 且 同 样 堪 称 经 典 。 


本 书 的 翻译 过 程 漫长 而 又 愉快 ， 书 中 的 精彩 内 容 不 断 给 我 们 以 惊喜 。Petzold 采用 的 
叙述 方式 奇特 却 又 如 此 自然 ,他 首先 从 历史 的 角度 审视 了 计算 机 技术 的 发 展 脉 络 ， 继 而 
自 底 向 上 地 将 计算 机 体系 结构 方面 的 知识 娓 娓 道 来 。 在 Petzold 的 笔触 下 ， 导 线 、 灯 泡 以 
及 触发 器 等 简单 部 件 ， 通 过 精妙 的 组 装 ， 况 然 构 建 出 了 一 台电 子 计算 机 ， 令 我 们 在 翻译 
的 过 程 中 不 禁 有 动手 一 试 的 冲动 ， 但 总 是 又 被 他 精彩 的 笔触 所 吸引 而 欲罢不能 。Petzold 
在 这 本 技术 书籍 里 旁 征 博 引 ， 从 美国 当红 的 影评 人 到 百年 之 前 的 布 莱 时 盲文 ， 从 史 密 
斯 . 索尼 亚 的 衫 尺 到 冯 : 诺 依 曼 的 构想 ， 从 石破天惊 的 论文 《思维 之 际 》 到 图 形 化 革命 ， 
看 似 信 手 牛 来 ， 然 则 处 处 别出心裁 。 


VI 


这 些 被 有 机 结合 起 来 的 零星 知识 ， 仿 佛 又 把 我 带 回 了 大 学 的 课堂 。 所 涉及 的 问题 包 
括 计 算 机 体系 结构 、 汇 编 语 人 
间 变 得 异常 清晰 而 且 格 外 生动 。 这 些 知识 原本 只 会 出 现在 高 校 的 计算 机 专业 课堂 里 ， 

人 惊奇 的 是 ， 局 管 遍布 于 世界 各 地 的 本 书记 者 往往 有 关 各 不 相同 的 专业 背 颖 ， 而 这 却 给 
毫 不 影响 本 书 内 容 所 带 给 他 们 的 震撼 ! 


所 谓 经 典 ， 就 是 历尽 岁月 的 洗涤 ， 依 然 毫 不 褪色 ， 然 其 光彩 却 历久 弥 新 。 我 想 本 书 
被 奉 为 经 典 之 作 当之无愧 。 

为 了 能 够 将 该 书 的 精彩 原原本本 地 呈现 给 广大 中 国 读者 ， 并 在 保证 质量 的 前 提 下 力 
争 让 该 书 早日 与 广大 读者 见面 ， 本 书 的 译 者 始终 秉持 着 谨慎 严 肃 的 态度 ， 对 许多 词句 都 
推 殴 再 三 ， 力 求 精益 求 精 。 在 此 期 间 ， 我 们 得 到 了 许多 师长 和 友人 的 支持 与 帮助 ， 感 激 
之 情 溢于言表 。 特 别 是 南京 航空 航天 大 学 本 秋 林 教授 ， 他 对 我 们 的 翻译 工作 给 予 了 极 大 
的 支持 ， 并 欣然 为 本 书 提 笔 作 序 ， 在 此 我 们 对 本 教授 表示 诚挚 的 谢意 。 


参与 本 书 翻译 工作 的 人 员 还 有 初 甲 林 、 剂 悦 、 高 新 、 高 阳 、 邓 明 强 和 赵 德 志 。 此 外 
赵 学 健 、 欧 阳 键 两 位 博士 也 参与 了 部 分 章节 的 审 校 工作 ， 在 此 也 向 他 们 一 并 表示 感谢 。 


在 本 书 即将 付 梓 之 际 ， 除 了 激动 喜悦 之 外 ， 译 者 又 多 了 一 份 性 蘑 ， 尽 管 我 们 几经 校 
对 ， 并 在 翻译 过 程 中 始终 以 谨慎 求实 的 态度 对 一 些 技术 细节 和 翻译 方式 反复 讨论 ， 力 求 
表意 准确 。 然 而 限于 时 间 仓 保 ， 丝 漏 和 欠缺 之 处 在 所 难免 ， 言 语 之 中 有 失 偏 颇 之 处 ， 还 
望 读者 不 音 赐 教 和 批评 。 联 系 信箱 : beckham@vip.163.com。 


薛 佟 佟 
2009 年 秋 于 南京 
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作者 序 


在 真正 开始 撰写 这 本 书 之 前 ,纷繁 的 思绪 在 我 的 脑海 中 已 经 蒙 绕 了 近 十 年 之 入 。 但 
从 着 手写 作 ， 一 直到 出 版 ， 我 不 断 反 复 地 问 着 自己 一 个 问题 : 这 本 书 是 讲 什么 的 ? 

关于 这 个 问题 我 总 是 找 不 到 合适 的 答案 。 我 想 说 :“ 这 本 书 将 带领 大 家 通过 一 段 信息 
技术 革命 的 旅程 重新 感触 现代 计算 机 技术 。” 语 毕 ,我 内 心 纠 结 ， 这 个 回答 真 的 将 这 本 书 
的 内 容 完整 诠释 出 来 了 吗 ? 


最 后 我 不 得 不 承认 :“ 这 本 书 其 实 是 讲述 计算 机 如 何 工作 的 。 


我 之 所 以 有 些 底气 不 足 ， 那 是 因为 我 已 经 猜 到 了 某 些 读者 的 反应 ;“ 嗨 ， 这 种 书 我 早 
就 读 过 了 。” 但 我 会 立刻 告诉 他 :“ 不 ， 这 种 书 你 并 没有 读 过 。” 对 于 这 点 ， 我 坚信 不 疑 。 
因为 这 本 书 并 不 是 讲 “计算 机 一 一 如 何 一 一 工作 "。 书 中 并 没有 用 一 张 又 一 张 描述 磁盘 的 
插图 ， 用 各 种 箭头 解释 数据 是 如 何 被 输送 到 计算 机 的 ， 书 里 面 也 没有 装载 着 一 节 又 一 节 
“0，1 数据 ”的 “火车 ”图 片 。 明 喻 与 暗喻 是 文学 描述 中 精妙 的 辅助 手段 ,但 它们 常常 掩 
瘟 了 科学 技术 的 真正 光芒 。 

我 还 听 过 另 一 个 说 法 :“ 人 们 不 愿意 了 解 计算 机 如 何 工作 。” 对 于 这 句 话 我 毫 无 保留 
地 赞同 ， 因 为 就 我 个 人 来 说 ， 也 是 在 不 经 意 之 间 才 体会 到 理解 事物 如 何 运 作 这 一 过 程 是 
多 么 有 趣 。 但 是 这 并 不 意味 着 我 对 世上 一 切 事物 的 运作 机 制 都 感 兴 趣 ， 都 有 所 了 解 ， 因 
此 我 绝对 不 会 在 任何 场合 向 大 家 解释 我 房间 里 冰箱 的 工作 原理 。 


然而 与 此 同时 ， 经 常 有 人 向 我 问 起 一 些 涉及 计算 机 内 部 运行 机 理 的 问题 。 一 个 常见 


i V 员 


的 例子 就 是 : “存储 器 ( storage )” 与 “内 存 (memory )” 有 何 区 别 ? ” 


对 于 计算 机 用 户 而 言 ， 这 个 问题 要 是 搞 不 清楚 ， 的 确 “ 寸 步 难 行 "， 可 以 看 到 ， 市场 
上 考察 个 人 计算 机 的 存储 性 能 ， 最 主要 的 就 是 这 两 个 概念 。 即 便 对 于 最 初级 的 计算 机 用 
户 来 说 ， 他 们 也 一 定 需要 了 解 到 底 多 少 “ 洲 字 节 ”或 多 少 “ 吉 字 节 ”的 存储 器 才能 应 对 
运行 在 其 上 的 程序 。 如 果 进 一 步 去 思考 ， 这 些 初级 用 户 或 许 更 加 想 了 解 计算 机 中 的 “ 文 
件 ” 是 什么 概念 ， 甚 至 连带 这 些 文件 如 何 从 存储 器 加 载 进 内 存 ， 又 如 何 从 内 存 存储 到 存 
储 器 ， 他 们 也 非常 期 望 学 习 这 些 知 识 。 


像 这 类 “存储 器 -内 存 ” 问 题 的 解答 大 都 使 用 类 比 法 :“ 内 存 就 好 比 你 的 办 公 桌 ,而 存 
储 器 就 好 比 你 的 文件 柜 。” 就 问题 本 身 而 言 ， 它 的 确 给 出 了 满意 的 回答 。 但 我 对 此 管 案 并 
不 满意 ， 主 要 原因 在 于 这 个 答案 将 计算 机 的 体系 结构 与 办 公 室 的 结构 等 同 起 来 ， 但 是 内 
存 与 存储 器 的 区 别 其 实 是 在 逻辑 层面 上 的 ， 它 体现 着 计算 机 体系 结构 的 实际 需求 与 存储 
器 客观 性 能 之 间 的 矛盾 ， 简 单 地 说 就 是 我 们 找 不 到 一 种 同时 具备 这 两 种 存储 器 所 有 优点 
的 存储 媒介 ， 这 些 优点 就 包括 存储 速度 块 、 存 储 容量 大 、 非 易 失 性 等 等 。 今 天 的 计算 机 
都 采用 “ 冯 : 诺 依 曼 体系 结构 ”一 一 五 十 年 来 它 一 直 是 计算 机 体系 结构 的 主导 , 而 内 存 与 
存储 器 的 区 分 也 正 是 由 于 这 种 体系 结构 的 不 足 所 导致 的 。 


还 有 一 些 计 算 机 用 户 问 我 这 样 一 个 问题 :“ 为 什么 Macintosh 环境 下 的 程序 不 能 在 
Windows 下 运行 ? ”我 想 立 刻 回 答 这 个 问题 ， 但 在 我 刚刚 张 开 嘴 的 时 候 就 立刻 意识 到 ， 
这 个 问题 涉及 太 多 的 技术 细节 ， 要 想 彻底 搞 清 楚 ， 那 提问 的 这 位 朋友 也 一 定 非 准备 和 我 
来 一 次 “茶话会 ”不 可 。 


我 希望 这 本 书 能 够 成 为 大 家 理解 这 些 问题 的 “助手 ”， 这 种 理解 我 希望 不 是 抽象 层 夯 
上 的 ， 而 是 具有 一 定 深度 的 ， 这 种 深度 甚至 不 逊 于 “电气 工程 师 ” 和 “程序 员 ” 的 理解 。 
我 同时 也 非常 希望 大 家 能 够 理解 : 计算 机 是 二 十 世纪 技术 领域 的 “登峰造极 之 作 ”， 它 是 
一 种 值得 欣赏 、 具 有 “ 美 ” 学 文化 底蕴 的 人 类 伟大 成 果 ， 这 种 “ 美 ” 不 需要 明 喻 与 暗喻 
的 额外 修饰 。 


计算 机 拥有 与 生 俱 来 的 层次 化 体系 结构 ， 这 种 结构 的 底层 是 晶体 管 ， 其 顶层 则 是 计算 
机 显示 器 上 所 呈现 的 信息 。 自 底 向 上 分 析 该 结构 的 每 一 层 一 -这 也 是 本 书 的 编写 结构 
其 实 这 一 切 并 没有 入 们 想象 中 那么 难 。 当 然 ， 现代 计算 机 的 内 部 结构 不 断 推陈出新 ， 但 
其 本 质 上 仍然 是 一 些 常见 且 简 捷 的 操作 集合 。 


| 


尽管 今天 的 计算 机 比 起 25 年 前 ， 以 及 50 年 前 的 都 复杂 许多 ， 但 它们 在 本 质 上 是 完 
全 一 致 的 。 学 习 技 术 发 展 史 的 重要 意义 正在 于 此 : 追溯 的 历史 越 和 久远， 技术 的 脉络 就 变 
得 越 清 晰 。 因 此 ， 我 们 需要 做 的 就 是 确定 某 些 关键 的 历史 阶段 ， 在 这 些 阶段 ， 技 术 最 天 
然 、 最 本 质 的 一 面 将 清晰 可 见 。 


在 这 本 书 中 ， 我 回溯 了 自己 所 能 找 得 到 资料 的 计算 机 发 展 史 。 令 我 自己 也 感到 惊讶 
的 是 ， 有 时 竟然 一 直 追 漳 到 19 世纪 ， 甚 至 使 用 了 早期 的 电报 设备 来 演示 计算 机 是 如 何 构 
建 的。 至少 从 理论 角度 来 看 ， 本 书 的 前 17 章 中 提 到 过 的 所 有 设备 ， 都 可 以 利用 已 经 存在 
了 一 个 世纪 的 简单 电子 器 件 来 构造 。 

这 些 古 董 级 技术 的 使 用 令 本 书 蒙 上 了 一 层 怀 旧 的 面纱 。 我 要 强调 的 是 Code 是 这 样 一 
本 书 ， 它 永远 不 会 被 命名 为 诸如 The Faster New Faster Thing 或 Business @ the Speed of a 
Digital Nervous System。o 在 这 本 书 中 ,“bit” 定义 在 第 70 页 ,“byte” 的 定义 则 出 现 于 第 186 
页 。 唱 体 管 直 到 第 146 页 才 被 介绍 ， 而 且 只 是 顺便 提 及 而 已 。 


在 对 计算 机 工作 原理 介绍 方面 ， 本 书 将 会 一 直 深 入 到 本 质 〈 例如， 只 有 少数 书 会 去 
介绍 计算 机 处 理 器 的 实际 工作 机 制 )， 但 整 本 书 的 节奏 是 相对 缓和 的 。 在 保证 内 容 深度 的 
基础 上 ， 我 尽量 使 读者 在 学 习 的 旅程 中 保持 轻松 愉悦 的 心情 。 


我 最 后 还 是 要 说 ， 书 里 面 没有 那 种 装载 着 一 人 又 一 节 “0，1 数据 ”的 “火车 ”图 片 。 


Charles Petzold 


2000 年 8 月 16 日 
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7 ”至 亲密 友 /1 


编码 是 什么 ? 在 本 书 中 ， 这 个 词 的 意 多 思 是 指 一 种 用 来 在 机 器 和 人 之 间 传递 信 
总 的 方式 。 摘自 话说 ,编码 就 是 交流 。 对 任何 能 听见 我 们 的 声音 并 理解 我 们 
所 说 的 语言 的 人 来 说 ,我 们 发 出 的 声音 所 形成 的 词语 就 是 一 种 编码 。 用 手电 
简 能 代替 声音 来 与 朋友 交谈 吗 ? 当然 值得 一 试 。 


有 编码 与 组 合 /17 四 


英 尔 斯 码 也 被 称 做 二 进 制 码 ， :的 这 外 必 避 的 肯 光 证 天 于 a 
和 “ 划 ”。 不 过 ,点 、 划 的 组 合 却 可 以 表示 你 想 要 的 任意 数目 的 码 字 。 这 其 
中 的 规律 是 什么 ? 本 章 我 们 就 来 探讨 一 备 。 


可 和 莱 叶 盲文 与 二 进 制 码 113 


布 某 叶 言 文 是 为 了 便于 言 人 阅读 而 发 明 的 一 _ 种 编码 。 在 这 一 章 中 我 们 将 解析 
布 莱 叶 盲文 ， 来 看 看 它 是 如 何 工作 的 。 我 们 并 不 是 要 真 的 学 习 布 菜 叶 育 文 ， 
而 且 也 无 须 刻 意 记 住 关于 它 的 什么 内 容 。 我 们 仅仅 希望 从 中 归纳 出 编码 的 一 
些 性 质 。 
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”手电 简 的 剖析 /21 Pe 


为 了 理解 电 在 计算 机 中 的 工作 原理 ， 我 们 先 得 仔细 钻研 一 得 电学 ， 不 要 
担心 人 ee 在 本 章 ， 我 们 将 以 手电 简 为 教学 
引导 你 走 入 神秘 的 电学 


_ 绕 过 拐角 的 通信 /32 


在 第 1 章 ， 我 们 曾经 讲 过 用 手电 简 与 朋友 进行 交谈 的 方法 ， 但 是 这 样 的 方式 
是 有 局 限 性 的 ， 你 的 交流 对 象 必须 住 在 街 对 过 ,而 且 你 们 卧室 的 窗口 正好 相 
对 。 但 是 ,现实 不 会 总 是 如 此 。 当 手电 简 的 光 无 法 到 达 朋 友 的 卧室 时 ， 和 上 怎样 
与 他 们 进行 无 声 的 交流 呢 ? 电路 或 许可 以 助 你 一 臂 之 力 。 


”电报 机 与 继电器 /40 ee 

全 球 性 即 时 通信 对 于 我 们 来 说 已 经 司 空 见 惯 ， 你 要 是 生活 在 19 世纪 早期 ， 
可 没 这 么 方便 。 你 当然 可 以 进行 即时 通信 或 者 远 距离 通信 ， 但 是 不 能 同时 做 
到 这 两 点 。 即 时 通信 受 声 音 传 播 距 离 的 限制 ， 或 者 受 视野 的 限制 。 使 用 信件 
倒是 可 以 进行 更 远 距 离 的 通信 ， 但 是 寄 信 耗费 的 时 间 太 多 ， 并 且 需 要 借助 于 
交通 工具 。 为 了 解决 这 个 问题 ， 电 报应 运 而 生 ， 而 伴随 着 电报 诞生 的 继电器 
更 是 具有 重要 意义 的 伟大 发 明 。 


”我们 的 十 个 数字 /47 


人 们 很 容易 理解 ， 语言 只 不 过 是 一 种 编码 。 比如 美文 中 的 at 怀 负 ) 在 其 
他 语言 中 可 以 写 做 gato、chat、Katze、KOIIK 或 katia。 然 而 ， 数 字 似 乎 并 

不 是 那么 容易 随 文化 的 不 同 而 改变 。 不 论 我 们 说 什么 语言 ， 或 使 用 什么 样 的 
音 ， 在 这 个 星球 上 的 所 有 人 都 用 以 下 方式 来 书写 数字 : 0 ，1，2，3，4， 

5，6，7，8，9。 你 了 解 这 十 个 数字 么 ? 


_ 十 的 蔡 代 品 /155 
对 人 类 而 言 ，10 是 一 个 非常 重要 的 数字 。 它 是 我 们 大 多 数 人 补 有 的 手指 或 
脚 中 的 数目 。 我 们 人 类 已 经 适应 了 以 10 为 基数 的 数字 系统 。 但 是 只 能 使 用 
十 进 制 来 计数 吗 ? 如 果 人 类 像 卡通 人 物 那 样 每 只 手 只 有 4 根 手 指 会 怎样 ? 
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二 进 制 数 /71 


二 进 制 是 是 最 简单 的 数字 系统 ， 其 中 只 包含 两 个 数字 ，， 0 0 和 1 Ls 。 二进制 中 的 1 
位 (bit ) 称 为 1 比特 ,我 们 可 以 用 它 来 表达 简单 的 信息 : 是 或 不 是 ; 亮 或 灭 ; 
打开 或 关闭 ， 等 等 。 而 事实 上 只 要 信息 能 转换 成 两 种 或 多 种 可 能 性 的 选择 ， 
就 都 可 以 用 比特 来 表示 。 这 种 例子 在 日 常生 活 中 随处 可 见 ， 比 如 照相 机 胶卷 
的 胶片 速度 ， 各 种 商品 包装 上 的 条 形 码 。 


”逻辑 与 开关 /90 ree 


对 于 十 希腊 人 而 言 ， 这 辑 是 在 追求 真理 的 过 程 中 所 使 用 的 一 _ 种 分 析 方法 ， 是 
一 种 哲学 形式 。 而 英国 的 数学 家 乔治 . 布尔 却 认为 可 以 找到 一 种 数学 形式 来 
描述 逻辑 , 因此 他 发 明了 布尔 代数 。 更 重要 的 是 , 布尔 代数 运算 可 以 用 开关 、 
导线 和 灯泡 组 成 的 电路 来 实现 ， 布 尔 代 数 中 的 AND 和 OR， 与 线路 中 开关 
的 串联 和 并 联 ， 有 着 奇妙 的 对 应 关系 。 


门 /1108 


继 电器 像 开 关 一 样 ， 可 以 久 囊 联 或 并 联 在 电路 中 执行 和 单 的 远 辑 任务 。 这 种 继 
电器 的 组 合 也 做 逻辑 门 (logic gate ) , 也 简称 门 。 这 里 提 到 的 逻辑 门 执行 “ 简 
单 ” 逻 辑 任务 是 指 逻 辑 门 只 完成 最 基本 的 功能 。 本 章 就 介绍 那些 用 以 完成 最 
基本 有 逻辑 任务 的 门 。 


进 制 加 法 器 /135 


”加 法 是 算术 计算 中 最 基础 的 运算 ， 如 果 起 搭建 一 台 计算 机 ， 首先 就 要 搭建 出 
计算 两 个 数 加 和 的 器 件 。 本 章 我 们 将 利用 前 面 章节 中 用 过 的 开关 、 灯 泡 、 导 
线 、 电 池 、 有 逻辑 门 等 这 些 简 单 的 元 件 ， 搭 建 一 个 二 进 制 加 法 器 。 


如何 实现 减法 1147 


当 你 确信 继电器 连接 在 一 起 真 的 可 以 实现 二 进 制 数 加 法 的 时 候 ， 你 可 能 会 
问 : “如 何 实现 减法 呢 ? ” 问 得 好 ! 这 表明 你 是 相当 有 觉察 力 的 ， 加 法 和 减 
法 在 某 些 方面 互相 补充 ,但 是 在 机 制 上 二 者 却 存 在 本 质 区 别 。 不 过 , 没关系 ， 
我 们 可 以 想 一 些 办 法 ， 把 减法 运算 变 成 加 法 。 
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了 可 反馈 与 须发 器 /180 四 


想象 一 下 ,如 果 休 没有 了 记忆 力 ， 该 如 何 去 数 数 ? 我 们 不 记得 刚刚 数 过 的 数 ， 
当然 也 就 无 法 确定 下 一 个 数 是 什么 ! 同 理 , 一 个 能 计数 的 电路 必定 需要 触发 
器 。 本 章 要 介绍 的 就 是 各 种 触发 器 。 


了 9。 字 节 与 十 六 进 制 /186 


在 前 面 的 章节 中 ， 加 和、 久 有 下 大和 二 和 大 才 
位 的 数据 流 ， 也 即 数据 路 径 的 位 宽 为 8， 为 什么 要 定义 为 8 位 呢 ? 为 什么 
是 6 位 、7 位 、9 位 或 10 位 ?9 本 章 就 要 解释 其 中 的 缘由 。 


了 6 存储器 组 织 /197 


每 天 清苦 ， 我 们 将 自己 从 沉睡 中 唤醒 ， 这 时 大 脑 的 空白 会 很 快 被 记忆 填 满 。 
我 们 立刻 会 意识 到 自己 身 在 何方 ， 最 近 做 了 些 什么 事情 ， 有 什么 计划 打算 。 
有 的 事情 我 们 很 快 就 能 想起 来 , 但 有 时 并 非 如 此 。 我 们 可 以 借助 许多 工具 来 
记录 信息 ， 比 如 笔 和 纸 、 磁 带 ， 当 然 现 在 还 可 以 使 用 存储 器 。 


了 /自动 操作 1215 


人 类 的 本 性 中 带 有 一 些 居 惰 的 特质 。 我 们 总 是 抠 触 繁重 的 工作 ， 对 村 淋 的 、 
重复 性 的 工作 深恶痛绝 。 所 以 , 当 你 必须 用 前 面 搭建 的 加 法 器 计算 100 个 数 ， 
其 至 更 多 个 数 的 加 法 时 ， 有 一 种 念头 就 会 不 可 遏制 地 从 脑子 里 冒 出 来 : 怎样 
让 加 法 器 自动 地 完成 数据 输入 和 计算 呢 ? 办 法 肯定 是 有 的 ， 那 就 是 编写 程 
序 。 


了 了。 从 算盘 到 芯片 /252 


算盘 、 滑 尺 、 纳 皮尔 :骨架 、 差 分 机 、 解 析 机 、 继电器 、 电 子 管 、 晶 休 管 、 世 
片 、 计 算 机 ; 甘 特 、 帕 斯 卡 、 莱 布 尼 族 、 杰 奎 德 、 巴 贝 芝 、 图 灵 、 冯 ，. 诺 依 
曼 、 香 农 ; IBM、 贝 尔 实验 室 …… 你 觉得 应 接 不 暇 了 吗 ? 把 这 些 你 或 熟悉 或 
生 朴 的 名 词 和 名 字 串 起 来 ， 就 是 人 类 的 计算 工具 发 展 史 。 让 时 光 倒 流 ， 去 看 
看 那些 精巧 的 工具 ， 感 受 天 才 们 的 巧 思 吧 ! 
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ASCII 而 码 和 字符 转换 /307 


两 种 典型 的 微 处 理 器 / 276 


将 中 央 处 理 器 的 所 有 构成 组 件 封装 到 一 块 硅 芯 片上 , 就 得 到 了 微 处 理 器 。 第 
一 片 微 处 理 器 芯片 诞生 于 1971 年 ， 即 Intel 4004 系列 ， 其 中 集成 了 2300 个 
晶体 管 , 你 或 许 觉得 马 如 今 家 用 计算 机 的 微 处 理 器 上 所 安置 的 晶体 管 
数量 已 经 以 亿 为 计量 单位 了 。 人 但是， 从 本 质 上 来 说 ， 微 处 理 器 实际 所 做 的 工 
作 并 没有 变 。 在 本 章 ,我 们 就 来 看 看 两 种 有 着 辉煌 历史 的 典型 微 处 理 器 : Intel 
8080 和 Motorola 6800。 


计算 机 中 的 存储 器 唯一 可 以 存储 的 形式 是 比特 ， 因此 如 果 想 在 计算 机 上 处 理 
信息 ， 就 必须 把 它们 转换 为 比特 的 形式 来 存储 。 我 们 已 经 掌握 了 如 何 用 比特 
来 表示 数字 和 机 器 码 。 如 何 用 它 来 存储 文本 呢 ? 毕竟 ， 人 类 所 积累 的 大 部 分 
信息 ， 都 以 各 种 文本 形式 保存 的 。 下 面 就 轮 到 ASCII 码 出 场 了 ! 


总 线 /325 


一 台 计 算 机 包括 很 多 部 件 : 中 央 处 理 器 、 存储 器 、 输入 /输出 设备 等 。 

ee 被 分 别 安装 在 两 个 或 更 多 的 电路 板 上 。 Re 通 
过 总 线 (bus ) 通信 。 如 果 对 总 线 做 一 个 简单 的 概括 ， 可 以 认为 总 线 就 是 数 
字 信 号 的 集合 ， 而 这 些 信 号 被 提供 给 计算 机 上 的 每 块 电路 板 。 


操作 系统 /346 本 二 二 

你 或 许 梦想 过 自 己 组 装 一 台 近 平 完整 的 计算 机 ， 像 老 木 偶 匠 六 羔 比特 腑 刘 木偶 
匹 诺 曹 一 样 ， 全 部 亲自 动手 用 小 零件 完成 。 不 过 在 你 的 机 器 能 完成 你 想 要 的 
操作 之 前 ， 还 差 一 个 重要 的 东西 一 -操作 系统 ! 


”定点 数 和 浮 点 数 /365 


整数 、 分 数 以 及 百分数 等 各 种 类 型 的 数字 与 我 们 形 影 不 让， 几 订 册 各 在 
们 生活 的 所 有 角落 。 例如 你 加 班 2.75 小时， 而 公司 按 正 常 工作 时 间 的 1.5 倍 
支付 你 工资 ， 你 用 这 些 钱 买 了 半 盒 鸡蛋 并 交 了 8.25% 的 销售 税 。 在 计算 机 的 
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hh XVI 


内 存 里 ， 所 有 的 数 都 表示 为 二 进 制 形式 。 通 过 前 面 的 学 习 ， 我 们 知道 2 用 二 
进 制 可 以 表示 为 10,， 可 是 2.75 用 二 进 制 怎样 表示 呢 ? 这 就 是 本 章 的 主题 。 


”高 级 语言 与 低级 语言 局 7381 


第 22 章 介 绍 了 如 何 编写 一 段 简单 的 程序 ， 让 我 们 可 以 利用 键盘 将 十 六 进 制 
机 器 码 输 入 计算 机 ,以 及 通过 视频 显示 设备 来 检查 这 些 代 码 。 但 是 使 用 机 器 
码 编写 程序 就 如 同 用 牙签 吃 东 西 ， 伸 出 手臂 费 半 天 劲 刺 向 食物 ， 但 每 次 都 只 
取 到 小 小 的 一 块 ， 用 这 种 低级 语言 编写 程序 既 费 力 又 费时 ， 有 悖 于 我 们 发 明 
计算 机 的 初衷 。 不 过 ,人 们 想 出 了 一 种 效率 更 高 的 编程 方法 一 一 使 用 高 级 语 
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图 形 化 革命 命 1398 


回顾 历史 ， 从 第 一 各 继电器 计算 器 到 现在 为 上 ， 六 七 十 年 过 去 了 ， ,计算 机 的 
处 理 速 度 飞 速 增长。 不 过 要 充分 利用 计算 机 日 益 增 长 的 运算 和 处 理 能 力 ， 就 
必须 不 断 改 进 计 算 机 系统 中 的 用 户 接 口 (User Interface ) ， 因 为 它 是 人 机 交 
互 的 轴 心 。 图 形 化 革命 来 了 ! 


你 今年 10 岁 ， 你 最 好 的 朋友 就 住 在 街 对 过 。 事 实 上 ， 你 们 各 自 卧 室 的 窗户 正好 彼此 
相对 。 每 当夜 幕 降 临 ， 父 母 就 如 同 往常 一 样 ， 早 早 地 催促 你 该 上 床 睡 觉 了 ， 但 是 你 和 你 
的 朋友 还 想 交 流 想法 ， 交 换 见 闻 ， 分 享 各自 的 秘密 ， 或 者 扯 扯 闲 话 ， 开 开玩笑 ， 聊 聊 梦 
想 。 这 本 无 可 厚 非 。 无 论 怎样 ， 渴 望 交流 本 来 就 是 人 类 最 主要 的 天 性 之 一 。 


当 卧 室 里 的 灯 依 然 亮 着 的 时 候 ， 你 可 以 和 朋友 互相 挥手 ， 使 用 各 种 手势 或 简单 的 肢 
体 语言 ， 来 表达 一 两 个 想法 。 但 是 ， 要 表达 复杂 的 想法 可 能 就 比较 困难 了 。 而 且 一 旦 父 
母 宣布 “ 关 灯 ”， 这 种 交流 似乎 也 不 可 能 继续 下 去 。 


如 何 交 流 呢 ? 或 许可 以 打 电话 ? 10 岁 小 孩 的 房间 里 会 有 电话 吗 ? 即使 有 ， 无 论 电 话 
在 哪里 ， 你 们 的 谈话 都 有 可 能 被 偷 听 。 如 果 你 家 里 的 电脑 连接 了 电话 线 ， 它 可 能 帮 上 忙 ， 
而 且 不 会 发 出 声响 ,但 是 一 等 等 ， 电 脑 也 不 会 在 你 的 房间 里 。 

你 和 朋友 所 采用 的 方法 就 是 使 用 手电 简 。 众 所 周知 ， 手 电 简 是 为 了 让 孩子 们 能 够 躲 
在 被 子 下 看 书 而 发 明 的 ;在 天 黑 后 用 手电 简 来 交流 信息 似乎 也 是 理想 的 选择 。 它 们 当然 
是 很 安静 的 ， 并 且 光 线 是 高 度 定 向 和 的， 同时 光线 也 不 会 渗 漏 出 卧室 而 引起 家 人 的 疑心 。 


手电 简 能 用 来 交谈 吗 ? 这 当然 值得 一 试 。 我 们 在 一 年 级 的 时 候 学 习 怎 样 在 纸 上 写 字 
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母 和 单词 ， 因 此 ， 把 同样 的 方法 运用 到 手电 简 上 似乎 也 是 有 道理 的 。 只 需要 站 在 窗户 边 ， 
用 光 来 画 出 字母 。 对 于 字母 “0”， 打 开 手 电 和 位， 在 空气 中 划一 个 圈 ， 然 后 关 挥 手电 简 。 
对 于 字母 “1”"， 竖 着 划一 下 。 但是， 你 很 快 就 会 发 现 ， 这 个 方法 也 不 太行 得 通 。 当 你 看 着 
朋友 的 手电 简 在 空中 圈 圈 点 点 时 ,会 发 现 很 难 在 头脑 中 组 合 出 那么 多 复杂 的 笔画 。 这 些 
旋转 和 倾斜 的 光线 都 太 不 准确 了 。 


或 许 大 家 都 曾经 在 电影 里 看 到 这 样 的 情节 ， 两 个 水 手 在 海上 通过 灯 的 亮 灭 来 互相 发 
送信 号 。 而 在 另 一 部 电影 里 ， 一 个 间谍 转动 一 面 错 子 将 太阳 光 反 射 到 刀 一 个 房间 里 ， 从 
而 向 被 俘 的 同伙 传递 信息 。 或 许 那 正 是 解决 问题 的 办 法 。 如 此 一 来 ， 你 就 可 以 发 明 一 种 
简单 的 技术 。 在 这 个 方案 里 ， 字 符 表 里 的 每 个 字符 对 应 一 连 串 的 手电 简 闪 烁 。“A” 是 闪 
一 次 ,“B” 是 内 两 次 ,“C” 是 内 三 次 ， 依 此 类 推 ,，“Z” 就 是 内 26 次 。 单 词 BAD 可 以 用 
闪 2 次 , 闪 1 次 , 闪 4 次 这 样 的 一 个 组 合 来 表示 ， 而 且 在 字符 之 间 设 置 的 小 停顿 使 这 个 
单词 不 至 于 被 误 认 为 是 内 7 次 的 字母 “G”。 另 外 ,单词 之 间 停 顿 可 以 稍 长 些 。 


这 似乎 很 有 希望 ， 采 用 这 种 方案 的 好 处 是 你 不 必 在 空中 比划 手电 简 了 ， 只 要 对 准 方 
向 和 按 开 关 就 行 了 。 但 是 这 种 方案 也 有 一 个 不 足 ， 那 就 是 如 果 你 想 发 送 的 第 一 个 消息 是 
“How are you? ”， 那 么 你 将 总 计 需 要 让 手电 简 闪 131 次 ! 而 且 ， 这 还 是 忽略 了 标点 符号 
的 ， 你 还 没有 设计 | 办 多 少 次 来 对 应 一 个 问号 。 


但 是 这 已 经 离 答 案 更 近 一 些 了 。 我 们 能 够 肯定 的 是 ， 在 此 之 前 一 定 有 人 也 遇 到 过 类 
似 的 问题 ， 而 你 解决 这 个 问题 的 思路 也 是 非常 正确 的 。 等 到 了 白天 ， 跑 一 趟 图 书馆 ， 查 
查 资料 ， 你 发 现 了 一 个 被 称 为 莫 尔 斯 电码 (Morse Code ) 的 伟大 发 明 。 这 正 是 你 想 找 的 ， 
尽管 你 现在 必须 重新 学 习 如 何 去 “ 写 ”字母 表 里 的 字母 。 


它们 的 不 同 之 处 在 于 : 在 你 发 明 的 系统 里 ， 字 母 表 里 的 每 个 字母 就 是 用 一 定数 目的 
闪光 表示 的 , 办 1 下 为 “A”, 闪 26 下 为 “Z”。 而 在 莫 尔 斯 电码 里 ， 则 有 两 种 闪烁 一 短 
闪 和 长 内 。 当 然 这 使 得 莫 尔 斯 电码 更 加 复杂 ， 但 是 在 实际 应 用 里 它 被 证 明 是 更 为 有 效 的 。 
句子 “How are you?” 现 在 只 要 闪 32 下 (包含 一 些 短 闪 和 一 些 长 内 )， 而 不 再 是 131 下 ， 
而 且 这 其 中 还 包括 了 一 个 代表 问号 的 编码 。 


当 问 及 莫 尔 斯 电码 是 如 何 工作 的 时 候 ， 人 们 并 不 会 谈论 “ 短 闪 ”与 “长 内 ”。 相 反 ， 
他 们 使 用 “点 (dot》 和 “ 划 (dash )， 因 为 这 是 在 打印 纸 上 显 示 编 码 的 一 个 便利 方法 。 
在 莫 尔 斯 电码 里 ， 字 母 表 里 的 每 个 字母 都 与 一 个 点 划 序 列 相对 应 ， 正 如 下 表 所 示 。 


让 2 


2 


虽然 莫 尔 斯 电码 和 计算 机 毫 无 关系 ， 但 是 ， 熟 悉 编码 的 本 质 对 于 深入 理解 计算 机 软 
硬件 内 部 结构 以 及 隐匿 在 其 后 的 语言 将 大 有 神 益 。 


在 这 本 书 里 ， 编 码 这 个 词 的 意思 是 指 一 种 用 来 在 机 器 和 人 之 间 传 递 信息 的 方式 。 换 
名 话说， 编码 就 是 交流 。 有 时 候 我 们 认为 编码 就 是 指 秘密 的 东西 〈 密码 )。 但 是 大 部 分 编 
码 不 是 这 样 的 。 毕 竞 ， 大 部 分 编码 必须 易于 理解 ， 因 为 它们 是 人 类 交流 的 基础 。 


在 《百年 孤独 》 这 本 书 的 开篇 里 ， 加 西亚 * 马尔 克 斯 回忆 了 一 个 时 代 ， 那 时 “这 个 
世界 刚刚 出 现 ， 以 至 于 很 多 东西 缺乏 命名 ， 这 时 就 有 必要 亲自 用 手指 明 这 些 事物 ”"。 我 们 
赋予 这 些 东西 名 字 时 往往 是 很 随意 的 。 这 就 好 比 说 为 什么 猫 不 被 叫做 “ 狗 ” 而 狗 不 被 叫 
做 “ 猫 ” 一 样 ， 没 有 什么 理由 可 言 。 你 可 以 说 英语 词汇 就 是 一 类 编码 。 


对 任何 能 听见 我 们 的 声音 并 理解 我 们 所 说 的 语言 的 人 来 说 ,我 们 发 出 的 声音 所 形成 
的 词语 是 一 种 可 识别 的 编码 。 我 们 将 这 个 编码 称 为 “口头 话语 (the spoken word 或 “ 言 
辞 (speech 》》。 对 于 写 在 纸 上 《 或 刻 在 石 尖 上 、 木 涉 上 , 或 者 在 空气 中 比划 ) 的 词 ， 我 们 
还 有 其 他 的 编码 方式 。 这 种 编码 以 手写 字符 或 打印 在 报纸 、 杂 志 以 及 书本 上 的 字符 形式 
出 现 。 我 们 叫 它 “ 书 面 语言 ( the written word ”或 “文本 (text》。 在 许多 语言 里 ， 语 言 
和 文字 之 间 存 在 着 很 紧密 的 联系 。 例 如 ， 英 语 中 的 字母 和 字母 组 合 与 它们 的 发 音 (或 多 
或 少 ) 存在 一 定 的 对 应 性 。 


对 于 那些 丧失 上 听 说 能 力 的 的 对 王 人 而 言 ， 人 们 发 明了 另 一 种 编码 来 帮助 他 们 进行 面 
对 面 的 交流 。 这 就 是 手语 。 手 语 通过 手 和 和 臂膀 形成 的 动作 和 姿势 来 传达 词语 中 的 单个 字 
符 或 者 整个 词语 ， 以 及 基本 的 概念 。 对 于 那些 失明 的 人 ， 书 面 语言 可 以 用 布 莱 叶 盲文 
( Braille ) 来 奉 代 。 这 种 文字 使 用 一 系列 凸 起 的 点 来 代表 字母 、 字 母 串 以 及 整个 单词 。 当 
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一 下 编码 隐匿 在 计算 机 软 硬 件 背后 的 语言 


话语 必须 快速 抄 成 文本 时 ， 缩 写 和 速记 都 是 很 有 用 的 。 


我 们 使 用 各 种 不 同 的 编码 来 为 我 们 自己 的 交流 服务 ， 因 为 有 些 编码 有 时 比 其 他 编码 
更 便捷 。 例 如 ， 话 语 的 编码 不 能 存储 在 纸 上 ， 因 此 ， 书 写 的 编码 就 被 用 来 蔡 代 话语 的 编 
码 。 如 果 在 黑暗 的 环境 下 ， 而 且 交 流 的 双方 之 间 有 一 定 的 距离 ， 那 么 通过 讲话 或 者 文字 
来 进行 秘密 的 信息 交换 几乎 是 不 可 能 的 ， 因 此 ， 莫 尔 斯 编码 就 成 了 一 个 方便 的 选择 。 如 
果 一 种 编码 可 以 用 在 其 他 编码 无 法 取代 的 地 方 ， 那 么 它 就 是 一 种 有 用 的 编码 。 


我 们 将 会 看 见 ， 各 种 类 型 的 编码 也 用 在 计算 机 里 来 存储 和 传递 数字 、 声 音 、 音 乐 、 
图 乒 和 电影 。 计 算 机 不 能 直接 处 理 人 类 的 编码 ， 因 为 计算 机 无 法 通过 与 人 类 的 限 睛 、 耳 
天 、 嘴 巴 和 手指 完全 相同 的 方式 来 接收 入 类 发 出 的 信息 。 然 而 ， 计 算 机 技术 的 一 个 最 新 
趋势 ， 已 使 得 我 们 的 个 人 计算 机 能 够 获取 、 存 侍 、 处 理 和 呈现 一 切 用 于 与 人 类 沟通 的 信 
息 , 无论 视觉 信息 (文字 和 图 片 )， 还 是 听觉 信息 〈 口 语 、 声 音 和 音乐 )， 或 两 者 的 相 结 
合 (动画 和 电影 )。 所 有 这 些 类 型 的 信息 都 需要 它们 各 自 的 编码 ， 就 像 人 类 说 话 需要 一 套 
器 官 《 嘴 和 耳 采 ) 而 写作 和 阅读 需要 另 一 套 〈 手 和 限 ) 一 样 。 


甚至 前 面 所 列 的 莫 尔 斯 编码 表 ， 其 本 身 就 是 一 种 类 型 的 编码 。 在 这 个 表 中 ， 每 个 字 
母 由 一 系列 的 “点 ”和 “ 划 ” 来 表示 。 然 而 实际 上 我 们 不 能 发 送 “ 点 ”和 “ 划 ”， 相 反 ， 
我 们 发 送 与 “点 ”和 “ 划 ” 对 应 的 闪烁 光 。 


当 使 用 手电 简 发 送 莫 尔 斯 编码 时 ， 迅 速 地 打开 和 关闭 开关 代表 一 个 “点 ”( 快 内 )， 
让 闪光 时 间 保 持 得 相对 长 一 些 代 表 “ 划 ”( 慢 速 闪光 )。 例 如 在 发 送 字母 A 时 ， 首 先 以 非 
常 快 的 速度 打开 并 关闭 手电 ， 然 后 再 以 稍 慢 的 速度 进行 一 次 。 在 发 送 下 一 个 字符 前 ， 需 
要 和 暂停 一 会 。 在 此 约定 ， 一 个 “ 划 ” 的 时 长 是 “点 ”的 3 倍 。 例 如 ， 如 果 一 个 “点 ”的 
时 长 是 1 秒 钟 ， 那 么 一 个 “ 划 ” 的 时 长 就 应 当 是 3 秒 钟 。( 在 现实 中 ， 莫 尔 斯 编码 的 传输 
速度 远 比 这 要 快 得 多 )。 接 收 者 看 到 一 个 短促 的 闪烁 和 一 个 扼 长 的 闪光 后 ， 就 知道 这 是 一 - 
个 A 了 。 


在 莫 尔 斯 编码 中 ,“ 点 ”和 “ 划 ” 之 间 的 停顿 是 至 关 重 要 的 。 例 如 ， 当 发 送 一 个 字母 
A 时 , 在 发 送 的 “点 ”和 “ 划 ” 之 间 ,， 手电 简要 关闭 一 段 时 间 ， 这 相当 于 一 个 点 的 闪烁 时 
长 如果“ 点 ”的 时 长 是 1 秒 钟 ， 那 么 “点 ”和 “ 划 ” 之 间 的 停顿 也 应 该 是 1 秒 钟 )。 对 
于 同一 个 单词 中 的 字母 , 则 通过 较 长 的 停顿 来 分 隔 ,， 这 大 约 相 当 于 一 个 “ 划 ” 的 时 长 (或 
者 说 是 3 秒 钟 ， 如 果 一 个 “ 划 ” 的 时 长 就 是 3 秒 钟 的 话 )。 下 图 以 “hello” 的 莫 尔 斯 编码 
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为 例 ， 说 明 字母 之 间 的 停顿 (间隙 )。 
TLE LI 


单词 之 间 则 通过 相当 于 两 个 “ 划 ” 的 时 长 来 分 隔 (如果 一 个 “ 划 ” 的 时 长 为 3 秒 钟 ， 
嘟 么 这 个 停顿 就 应 当 为 6 秒 钟 )。 例 如 下 图 是 “hi there” 所 对 应 的 编码 。 


需 夫 帮手 夫 着 人 
手电 简 开 和 关 的 时 长 并 没有 限定 。 它 们 都 与 一 个 “点 ”的 时 长 相关 ， 而 这 依赖 于 手 
电 简 开关 能 以 多 快 的 速度 扳 动 ， 以 及 莫 尔 斯 编码 的 发 送 者 能 以 多 快 的 速度 记 下 一 个 指定 
字符 。 对 于 一 个 快速 发 送 者 ， 他 的 “ 划 ” 的 时 长 ， 也 许 只 相当 于 一 个 慢 速 发 送 者 的 “点 ” 
的 时 长 。 这 会 带 来 一 个 小 间 题 ， 即 阅读 莫 尔 斯 编码 信息 会 变 得 很 困难 ， 但 是 经 过 一 两 个 
字母 之 后 ， 接 收 者 通常 就 可 以 分 清楚 哪 一 个 是 “点 "” ， 哪 一 个 是 “ 划 ” 了 。 


乍 一 看 ， 莫 尔 斯 编码 的 定义 与 打字 机 字母 的 排列 一 样 都 是 随意 的 。 这 里 的 定义 是 指 
字母 表 中 的 字母 与 各 种 “点 ”和 “ 划 ” 的 组 合 序 列 之 间 的 对 应 关系 。 然 而 ， 仔 细 研 究 之 
后 ， 我 们 就 会 发 现 事实 并 非 完全 如 此 。 简 单 且 短 促 的 编码 ， 被 分 配给 字母 表 中 使 用 频率 
较 高 的 字母 , 例如 三 和 T。 拼 字 比 赛 选手 和 “地 运 轮 ” 的 粉丝 们 可 能 会 很 快意 识 到 这 一 点 。 
而 不 太 常用 的 字母 ， 比 如 Q 和 Z (这 只 会 让 选手 在 拼 字 中 得 到 10 分 ) 则 被 分 配 以 较 长 的 
编码 。 


| 


几乎 每 个 人 都 知道 一 点 儿 莫 尔 斯 编码 。 三 个 点 、 三 个 划 ， 再 加 三 个 点 就 表示 SOS， 
即 国际 求救 信号 。SOS 不 是 一 个 缩写 ， 这 只 是 一 个 易于 记忆 的 莫 尔 斯 编码 序列 。 在 第 二 
次 世界 大 战 期 间 ， 英 国 广播 公司 一 些 无 线 电 广播 以 贝多 芬 第 五 交响 曲 的 片段 来 作为 节目 
的 前 奏 一 BAH, BAH，BAH，BAHMMMMM, 而 贝多 芬 绝 不 会 想到 他 所 谱写 的 这 段 乐 
曲 可 以 表示 为 莫 尔 斯 编码 的 V， 即 胜利 (Victory ) 之 意 。 


莫 尔 斯 编码 的 一 个 缺点 是 ， 它 没有 区 分 大 写字 母 和 小 写字 母 。 但 是 除了 可 以 代表 字 
母 外 ， 莫 尔 斯 编码 还 使 用 一 组 由 点 和 划 组 成 的 五 元 序列 来 表示 数字 ， 如 下 所 示 。 


让 
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还 有 一 些 编码 则 用 来 表示 某 些 欧洲 语言 中 的 重音 字母 ， 以 及 用 于 特殊 目的 的 速记 序 


列 。 如 SOS 的 编码 就 是 这 样 的 一 个 速记 序列 ; 必须 连续 地 传递 这 三 个 字母 ， 而 且 字 母 之 
间 只 有 一 个 点 的 停顿 时 间 。 


如 果 有 一 个 专门 为 此 设计 的 手电 简 的 话 ， 你 会 发 现 和 朋友 之 间 通 过 莫 尔 斯 编码 交流 
将 变 得 更 加 简单 。 除 了 一 个 可 以 滑动 的 开关 外 ， 这 种 手电 简 还 有 一 个 按钮 开关 用 来 控制 
灯光 的 明 灭 。 在 一 些 实际 应 用 中 ,可 以 达到 每 分 钟 传递 5 到 6 个 单词 的 速度 一 一 虽然 这 仍 
比 讲话 慢 得 多 ( 讲话 的 速度 在 每 分 钟 100 个 单词 左右 )， 但 这 已 经 足够 了 。 


当 你 和 朋友 最 终 熟 记 了 英 尔 斯 编码 之 后 ( 这 是 能 熟练 地 收发 编码 的 唯一 方法 )， 你 们 
甚至 可 以 在 口语 中 使 用 它 ， 用 来 取代 正常 的 语言 。 为 了 使 编码 发 送 的 速度 最 快 ， 你 可 以 
把 “点 ” 读 作 “ 咬 (dib 六 ， 把 “ 划 ” 读 作 “ 噶 ( dab 六。 文字 也 可 以 用 同样 的 方式 简化 成 
“点 ”和 “ 刘 ” 的 序列 ， 葛 尔 斯 编码 的 口语 版 把 讲话 内 容 缩 减 到 只 剩 下 两 个 声音 了 。 


问题 的 关键 就 在 于 数字 2。 两 种 闪烁 ,两 种 声音 。 事 实 上 ， 两 个 不 同 的 事物 ， 只 要 经 
过 适当 的 组 合 ， 就 可 以 表示 所 有 类 型 的 信息 ， 这 的 确 是 干 真 万 确 的 。 


莫 尔 斯 码 《Morse Code ) 是 由 塞 缪 尔 : 莫 尔 斯 发 明 的 《1791-1872 )， 在 本 书 的 其 他 章 
节 中 我 们 还 将 频繁 地 提 到 他 。 英 尔 斯 码 其 实 是 伴随 着 电报 机 的 问世 而 被 发 明 的 ， 关 于 电 
报 机 ， 我 们 在 后 面 也 将 做 详细 的 探讨 。 正 如 通过 研究 莫 尔 斯 码 我 们 可 以 很 方便 地 理解 编 
码 的 本 质 一 样 ， 通 过 电报 机 来 了 解 计算 机 硬件 也 是 个 不 错 的 途径 。 


大 多 数 人 都 会 发 现 莫 尔 斯 码 的 发 送 比 接收 更 为 简单 。 即 使 你 并 没有 熟 记 莫 尔 斯 码 ， 
也 可 以 很 方便 地 使 用 下 面 这 张 按 字母 表 顺 序 排 列 的 表格 。 


比 起 发 送 莫 尔 斯 码 ， 接 收编 码 并 进行 解码 要 费时 费力 得 多 ， 因 为 译 码 者 不 得 不 根据 


串 由 “点 "、“ 划 ”组 成 的 睡 涩 的 编码 序列 来 反 查 字 母 。 例 如 ， 如 果 你 接收 到 一 串 形 如 
“ 划 - 点 - 划 - 划 ”的 编码 ， 那 么 你 就 必须 从 表 的 第 一 个 字母 开始 逐个 搜寻 ， 直 到 找到 与 这 
是 编 码 相 符 的 字母 “Y” 为 止 。 


问题 就 出 在 这 里 ， 因 为 我 们 现在 只 有 一 张 提 供 “字母 一 莫 尔 斯 码 ”的 编码 表 ， 而 
缺少 一 张 可 以 实现 反 向 查询 的 “ 莫 尔 斯 码 一 字母 ” 译 码 表 。 在 开始 学 习 莫 尔 斯 码 的 初级 
阶段 ， 如 果 有 这 样 的 一 个 表 无 疑 将 是 很 方便 的 。 但 是 要 建立 这 样 一 张 表 ， 谈 何 容 易 。 似 
乎 这 些 字 母 对 应 的 “点 - 划 ” 序 列 并 没有 什么 规律 。 


所 以 忘掉 字母 序列 吧 。 或 许 根据 编码 中 所 包含 点 、 划 的 多 少 来 对 其 进行 分 组 ， 是 一 
个 更 好 的 组 织 这 些 编码 的 方法 。 例 如 ， 一 个 仅 包含 一 个 点 或 一 个 划 的 莫 尔 斯 码 只 能 代表 
两 个 字母 ，“E” 或 “T"。 


一 组 含有 2 个 点 或 划 的 编码 组 合 ， 可 以 给 我 们 呈现 出 4 个 字母 一 I, A,， N 和 M。 


五 吉 右 马 本 这 呈 天 
本 四 本 芭 及 订 


一 组 含有 3 个 点 或 划 的 莫 尔 斯 码 可 以 为 我 们 表示 更 多 的 字母 。 


~ 


最 后 ( 如 果 我 们 不 想 考 虑 存在 数字 和 标点 符号 的 莫 尔 斯 码 的 情况 )， 一 串 由 4 个 点 或 
划 组 成 的 莫 尔 斯 码 就 可 以 表示 16 个 字符 。 
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综合 以 上 数据 来 看 ， 这 四 张 表 包 含 了 2 十 4 十 8 十 16 组 码 字 ， 总 共 表示 了 30 个 字母 ， 
比 拉 丁字 母 表 的 26 个 字母 还 要 多 出 4 个。 所以， 你 会 注意 到 最 后 一 个 表 中 有 4 组 编码 是 
用 来 表示 重音 字母 的 。 


当 有 人 给 你 发 送 莫 尔 斯 码 的 时 候 ， 上 述 四 张 表 可 能 会 让 你 的 解码 工作 变 得 轻松 很 多 。 
当 接 收 到 某 一 代表 特定 字母 的 码 字 后 ， 你 就 可 以 知道 其 中 所 包含 的 “点 ”和 “ 划 ” 的 数 
目 ， 那 么 你 至 少 可 以 很 快 找到 对 应 的 表格 去 进行 查找 。 每 个 表格 都 组 织 得 很 规整 ， 全 部 
是 “点 ”的 码 字 被 排 在 左上 角 ， 而 全 部 是 “ 划 ” 的 则 被 排 在 右 下 角 。 


你 发 现 这 四 张 表格 在 大 小 上 的 规律 了 么 ? 注意 看 ， 每 个 表格 所 包含 的 码 字 数目 都 是 
前 一 张 的 两 倍 。 这 其 实 很 好 理解 : 每 个 表格 所 含有 的 码 字 ， 可 以 看 成 是 在 前 一 张 表格 所 
包含 的 全 部 码 字 上 再 加 一 个 “点 ”， 或 者 再 加 一 个 “ 划 ” 而 组 成 的 新 码 字 。 


我 们 可 以 用 如 下 这 样 一 个 列表 来 总 结 这 个 有 趣 的 规律 。 
点 和 划 的 数目 码 字 的 数目 


在 这 四 个 表 中 ， 每 张 表 的 码 字 数 都 是 前 一 张 表 码 字 数量 的 两 倍 ， 因 此 如 果 第 一 张 表 
含有 2 个 码 字 ,那么 第 二 张 表 则 含有 2x2 个 码 字 ， 而 第 三 个 表 就 有 2x2x2 个 码 字 。 下 
面 用 男 一 种 方式 呈现 这 个 规律 。 


当然 ， 如 果 我 们 遇 到 了 数字 的 自 乘 ， 就 可 以 通过 需 的 方式 来 表示 它 。 例 如 ，2x2x2 
x2 可 以 记 作 2 (2 的 4 次 寡 ) 数字 2、4、8 和 16 都 是 以 2 为 底数 的 罕 值 ， 因 为 你 可 以 
通过 使 其 自身 乘 2 来 得 到 它们 。 由 此 我 们 的 总 结 列表 也 可 以 写成 下 面 这 种 样子 。 
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点 和 划 的 数目 | 码 字 的 数目 
中 


现在 这 个 表 已 经 变 得 很 简洁 了 。 如 果 知 道 了 码 字 中 “点 ”和 “ 划 ” 的 数目 ， 那 么 以 
这 个 数目 为 指数 的 2 的 寡 运 算 结 果 就 是 其 总 共 可 以 表示 的 码 字 数 。 我 们 可 以 用 下 面 这 个 
简单 的 公式 来 概括 上 述 表 格 所 表示 的 内 容 : 


码 字 的 数 目 运力 "点 ”和 “ 划 ” 的 数目 


使 用 2 的 竹 值 的 形式 可 以 表示 很 多 码 字 ， 在 下 一 章 中 ,我们 还 将 接触 男 外 一 个 例子 。 


为 了 让 葛 尔 斯 码 的 解码 过 程 更 加 简单 ,或许 画 张 图 会 有 所 帮助 , 例如 下 面 这 张 树 型 图 。 


这 张 图 给 出 了 所 有 字母 及 其 所 对 应 的 由 “点 ”和 “ 划 ” 组 成 的 连续 序列 。 当 对 一 叮 
码 字 进 行 解 码 时 ， 我 们 需要 沿 着 箭头 从 左 向 右 进 行 搜寻 。 以 “点 - 划 - 点 ”的 码 字 为 例 来 
说 ， 当 你 需要 找 出 这 串 码 字 所 代表 的 字母 时 ， 应 首先 从 图 的 左边 开始 ， 选 择 “点 ”的 分 
支 ; 然后 继续 沿 着 箭头 向 右 选 择 “ 划 ”， 接 着 又 是 一 个 “点 "。 找 到 最 后 一 个 “点 ”时 结 
果 就 会 紧 随 其 后 出 现 了 ， 没 错 就 是 字母 “R”。 
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如 果 仔 细 想 一 想 ， 你 就 会 发 现 构建 这 样 一 个 表 对 于 定义 莫 尔 斯 码 规范 来 说 是 很 必要 


四 与 组 合 -六 一 
A 


的 。 首 先 ， 它 确保 了 我 们 不 会 对 不 同 的 字母 定义 相同 的 码 字 。 其 次 ， 通 过 这 个 表 我 们 可 
以 用 尽 可 能 短 的 码 字 来 表示 所 有 的 字母 ， 而 避免 产生 编码 长 度 上 的 浪费 。 

我 们 可 以 继续 加 长 码 字 至 5 位 或 者 更 长 ， 不 过 这 可 能 超出 页 面 打印 边界 。 一 串 由 5 
个 “点 ”或 “ 划 ” 组 成 的 编码 囊 可 以 为 我 们 提供 32 (2x2x2x2x2， 或 2 ) 种 扩展 的 
码 字 。 对 于 莫 尔 斯 码 中 定义 的 10 个 数字 和 16 个 标点 符号 来 说 ， 通 常 这 已 经 足够 了 ， 而 


实际 上 数字 确实 就 是 使 用 5 位 的 莫 尔 斯 码 来 表示 的 。 但 是 媚 


字 常 用 来 表示 重音 字母 而 不 是 标点 符号 。 
为 了 把 所 有 的 标点 符号 也 都 包含 进去 ， 编 码 系统 必须 要 扩展 到 6 位 了 ! 扩展 后 将 为 


我 们 提供 64 


FE 很 多 其 他 编码 方式 中 ，5 位 码 


2x2x2x2x2x2， 即 2 ) 种 新 增 的 码 字 ， 这样 总 共 的 码 字 就 达到 了 


2+4+8+16+32+64, 也 就 是 126 种 ! 这 对 莫 尔 斯 码 来 说 有 点 太 多 了 ， 甚 至 还 留 下 了 很 


多 “未 定义 ”的 码 字 。 这 里 “未 定义 ”] 
接收 莫 尔 斯 码 的 时 候 收 到 了 一 个 未 定义 码 字 ， 可 以 肯 


来 表示 那些 不 代表 任何 字符 的 码 字 。 如 果 你 在 


我 们 很 容易 就 能 得 到 这 样 一 个 小 公式 : 


利用 它 就 可 以 继续 计 


幸运 的 是 ， 我 们 二 


码 字 的 数目 一 2 9 


定 发 送 方 一 定 是 出 了 差错 。 


只 是 让 2 不 断 地 与 自 


, 相 


出 更 长 位 数 的 点 划 序 列 所 能 表示 的 码 字 数目 了 。 
点 划 的 数目 

1 21=:2 

2 22=4 

4 24= 16 

5 25=32 

6 2°=64 

8 23 =256 

9 2 = 512 

10 21° = 1024 


Ff 不 需要 写 出 所 有 可 能 的 码 字 来 计算 码 字 的 总 数 


乘 。 


目 。 我 们 需要 做 的 


11 霹 


下 编码 一 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 


莫 尔 斯 码 也 被 称 作 二 进 制 码 ( Binary Code )， 因 为 这 种 编码 的 组 成 元 素 只 有 两 个 一 
“点 ”和 “ 划 ”"。 这 跟 硬币 有 些 类 似 ， 因 为 硬币 落 到 地 上 只 能 是 正面 朝 上 或 反面 朝 上 。 一 
元 对 象 (例如 硬币 ) 和 二 进 制 码 ( 例如 莫 尔 斯 码 ) 常常 使 用 2 的 乘 方 来 进行 描述 。 


上 面 所 做 的 关于 二 进 制 编码 的 分 析 工 作 ， 其 实 是 数学 的 一 个 分 支 ， 称 作 “ 组 合 学 ” 
或 “组 合 分 析 ”， 而 我 们 所 作 的 分 析 则 只 能 说 是 一 个 简单 的 练习 。 传 统 意义 上 来 说 ， 因 
为 组 合 分 析 涉 及 类 似 像 扔 硬币 、 毛 角 子 这 样 的 需要 对 其 组 合 数目 进行 推算 的 问题 , 所 以 
它 经 常 被 应 用 到 概率 和 统计 学 中 。 但 是 它 对 于 我 们 理解 码 字 的 组 合 与 分 解 也 是 十 分 有 帮 
助 的 。 


.12 


”| 

| BD 

“” 布 亲 叶童 义 与 
二 进 制 友 

塞 继 尔 '. 莫 尔 斯 并 不 是 第 一 个 将 书面 语言 的 字母 成 功 编码 的 人 。 实 际 上 ， 在 因 自 


的 名 字 被 用 来 命名 某 种 编码 方式 而 名 声 大 品 的 人 中 ， 莫 尔 斯 先生 也 不 是 第 一 人 。 这 项 
誉 应 该 归 一 个 法 国 宦 人 小 伙 子 所 有 。 尽 管 他 比 莫 尔 斯 要 晚 出 生 18 年 ， 但 是 他 很 早 就 创 


| 


了 自己 的 编码 规范 。 他 的 生平 鲜 为 人 知 ， 尽 管 关于 他 的 故事 流传 至 今 的 为 数 不 多 ， 但 这 


也 足以 构成 一 个 引信 注目 的 传奇 。 


路 易 斯 : 布 莱 叶 (Louis Braille ) 于 1809 年 生 于 法 国 的 库 普 雷 ， 
这 是 一 个 距离 巴黎 市 东 只 有 25 英里 的 小 镇 。 布 菜 叶 的 父亲 是 一 个 
马 具 匠 人 。 在 布 莱 叶 3 岁 的 时 候 一 一 个 本 不 该 在 父亲 的 工作 间 玩 
要 的 年 纪 一 一 他 不 小 心 被 一 个 尖锐 的 工具 刺 伤 了 一 只 眼睛 。 伤 口感 
染 也 影响 到 了 他 的 另外 一 只 眼睛 ， 最 后 使 他 的 双 目 完全 失明 。 按 
- 常理 ， 布 莱 叶 将 在 无 知 和 贫困 当中 度 过 自己 的 一 生 ( 就 像 当 时 大 
部 分 盲人 那样 )， 但 是 小 路 易 斯 对 知识 的 渴望 和 过 人 的 智慧 很 快 被 


记 
荣 
建 
这 


下 编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 


人 们 所 发 现 。 他 最 初 同 其 他 孩子 一 样 在 镇 上 的 小 学 上 学 ， 后 来 在 他 10 岁 的 时 候 ， 在 小 镇 
牧师 和 一 名 学 校 老师 的 帮助 下 ， 布 莱 叶 被 送 往 巴黎 皇家 盲人 学 校 学 习 。 


很 显然 ， 盲人 教育 中 一 个 主要 的 障碍 就 是 盲人 无 法 阅读 印刷 的 书籍 。 瓦 伦 丁 . 霍 伊 
(1745-1822 ), 巴黎 皇家 盲人 学 校 的 创始 人 , 曾 发 明 过 一 种 在 纸 面 上 印 下 睛 起 文字 的 系统 ， 
这 样 盲人 就 可 以 通过 触摸 的 方式 来 进行 阅读 了 。 但 是 这 种 文字 系统 使 用 起 来 很 困难 ， 而 
且 使 用 这 种 方法 来 印刷 的 书籍 也 非常 少 。 


霍 伊 先生 视力 健全 ， 因 此 他 被 自身 的 感知 模式 所 禁 钢 。 对 他 来 说 ， 一 个 字母 A 就 是 
一 个 A， 而 且 字母 A 在 记录 时 也 必须 看 起 来 (或 者 感觉 起 来 ) 像 一 个 A (如果 让 他 用 手 
电 简 交流 的 话 ， 估 计 他 会 像 我 们 最 开始 所 做 的 那样 ， 试 图 在 空中 比划 出 要 表达 的 字母 ， 
但 其 实 我 们 发 现 这 法 子 根本 不 灵 )。 霍 伊 先生 或 许 没 有 意识 到 ， 有 一 种 完全 不 同 于 印刷 字 
母 的 文字 系统 可 能 更 加 适合 言 人 阅读 。 


这 种 非常 规 编码 方式 的 起 源 说 出 来 可 能 有 些 出 人 意料 。 查 尔 斯 巴 比 尔 〈Charles 
Barbier )， 法 国 军 队 的 一 位 军官 ， 在 1819 年 发 明了 一 种 他 自称 为 “écriture nocturne”( 也 
叫 “ 夜 闻 书 写 ”) 的 文字 系统 。 他 在 厚 纸 上 使 用 凸 起 的 点 和 划 的 组 合 来 表示 文字 ， 这 样 当 
部 队 需 要 无 声 交流 的 时 候 ， 即 使 光线 很 暗 ， 士 兵 们 也 可 以 通过 这 些 符 号 互相 传递 信息 。 
他 们 使 用 一 个 锥 形 的 铁 笔 在 厚 纸 的 背面 书写 ， 这 样 纸 的 正面 就 会 有 相应 的 凸 起 。 然 后 人 
们 就 可 以 使 用 手指 触摸 这 些 凸 起 的 点 和 划 来 进行 阅读 了 。 


书 比尔 文字 系统 的 缺点 是 太 过 复杂 了 。 该 系统 并 非 使 用 与 字母 表 相 对 应 的 点 划 编 码 
串 来 表示 字母 ， 而 是 用 与 读音 相对 应 的 编码 串 表 示 ， 因 此 有 时 仪 仅 是 为 了 表示 一 个 单词 ， 
就 不 得 不 使 用 很 多 的 码 字 。 如 果 只 是 传递 简短 的 消息 ， 这 个 系统 用 起 来 倒 还 不 错 ; 但 是 
在 表示 长 文本 的 时 候 ， 就 明显 力不从心 ， 就 更 别 说 用 来 对 整 本 书 进行 编码 了 。 


布 莱 叶 在 12 岁 的 时 候 就 很 熟悉 巴 比 尔 的 这 种 文字 系统 了 。 他 特别 喜欢 使 用 凸 起 的 点 ， 
不 仅仅 因为 凸 起 的 点 通过 手指 就 可 以 很 容易 实现 阅读 ， 还 因为 它们 “ 写 ” 起 来 也 很 简单 。 
在 教室 里 ， 一 个 言 人 学 生 如 果 有 了 纸张 和 铁 笔 ， 他 就 可 以 做 笔记 ， 而 且 同 时 还 能 阅读 记 
下 来 的 文字 。 路 易 斯 ， 布 菜 叶 开始 不 辞 辛劳 地 改进 这 个 文字 系统 ，3 年 以 后 ( 那 时 他 15 
岁 ) 就 创建 成 了 自己 的 系统 ， 而 这 个 系统 中 的 一 些 基 本 规范 ， 直 到 今天 仍 在 被 人 们 所 使 
用 。 在 很 长 一 段 时间 内 ， 这 种 新 的 文字 系统 只 被 他 们 学 校内 部 的 人 们 所 熟悉 ， 但 是 渐 交 
地 , 布 莱 叶 盲文 传播 到 了 世界 的 各 个 角落 。1835 年 , 路 易 斯 ' 布 菜 叶 患 上 了 肺结核 。1852 


如 14 


3 布 莱 叶 盲文 与 二 进 制 码 -f 
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年 ， 就 在 布 莱 叶 43 岁 生 日 刚 过 完 不 入 ， 病 魔 无 情 地 夺 走 了 他 的 生命 。 


如 今 , 在 引导 盲人 进入 文字 殿堂 的 道路 上 ， 改 进 后 的 布 莱 叶 盲文 系统 与 磁带 录音 书 
进行 着 竞争 ， 但 是 布 莱 叶 语文 仍然 是 不 可 替代 的 工具 ， 特 别 是 对 于 又 全 又 言 的 人 来 说 ， 
布 莱 时 盲文 仍然 是 他 们 开启 阅读 大 门 的 唯一 钥 是 。 近 些 年 来 ， 布 莱 叶 盲文 被 越 来 越 多 地 
应 用 到 公共 场所 中 ， 使 得 盲人 朋友 们 可 以 越 来 越 方便 地 使 用 电梯 、 自 动 取款 机 等 设备 。 

在 这 一 章 中 我 们 将 解析 布 莱 叶 语文 ， 来 看 看 它 是 如 何 工 作 的 。 我 们 并 不 是 要 真 的 学 
习 布 莱 叶 盲文 ， 而 且 也 无 须 刻 意 记 住 什么 关于 它 的 内 容 。 我 们 仅仅 希望 从 中 窥探 到 编码 
的 一 些 本 质 。 


器 


在 布 莱 叶 讶 文中, 每 个 在 书写 文字 中 用 到 的 符号 一 一 具体 来 说 就 是 字母 、 数 字 和 标点 
符号 一 一 都 被 编码 成 为 2x3 的 点 码 单元 中 的 一 个 或 者 多 个 凸 起 的 点 。 这 个 点 码 单元 包含 的 
点 通常 使 用 1 到 6 的 数字 来 编号 。 


1OO: 
2 OO OO 
3 (6 

在 现代 应 用 中 ， 使 用 特殊 的 打印 机 或 轧 花 机 可 以 将 布 莱 叶 盲文 印 到 纸张 上 。 


So 


即使 只 是 用 布 莱 叶 盲文 在 本 书 中 印 上 几 页 ， 造 价 也 实在 是 有 点 儿 高 ， 所 以 我 在 书 中 
使 用 一 种 符号 来 表示 布 莱 叶 语文。 在 这 种 表示 方法 中 ， 点 码 单元 中 所 有 的 6 个 点 都 会 被 
表示 出 来 。 大 点 表示 这 是 一 个 凸 起 的 点 ， 小 点 则 表示 其 对 应 的 位 置 是 平 的 。 例 如 ， 下 面 
的 布 莱 叶 盲文 : 


过 . 
其 中 ， 第 1，3，5 点 是 凸 起 的 ， 而 第 2，4，6 点 的 位 置 是 平 的 。 
令 我 们 感 兴 趣 的 是 ， 这 些 点 码 都 是 二 进 制 的 。 一 个 单独 的 点 不 是 乎 的 就 是 凸 起 的 。 
也 就 是 说 我 们 可 以 把 在 莫 尔 斯 编码 中 学 到 的 知识 应 用 到 布 菜 叶 育 文 的 分 析 中 ! 我 们 现在 


已 经 知道 ， 每 组 有 6 个 点 ， 并 且 每 个 点 有 平和 凸 两 种 状态 ， 因 此 6 个 可 平 可 出 的 点 的 组 
合 数 就 是 2x2x2x2x2x2， 即 26， 也 就 是 64。 


15 才 


一 了 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
E en Ha 


因此 , 布 莱 叶 盲文 系统 能 够 表示 64 个 不 同 的 码 字 。 下 图 就 是 所 有 可 能 的 64 种 码 字 。 
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假如 发 现 布 莱 叶 盲文 中 用 到 的 码 字 数目 少 于 64, 就 会 有 人 问 了 , 为 什么 64 个 可 能 的 
码 字 中 有 一 些 被 遗弃 不 用 呢 ? 假如 我 们 发 现 布 莱 叶 盲文 中 用 到 的 码 字数 目 超 过 64， 问 题 就 
更 严重 了 ,我 们 会 怀疑 自己 的 智商 ,甚至 怀疑 基本 的 数学 原理 一 一 到 底 2 加 2 是 不 是 等 于 4。 


还 是 让 我 们 来 开始 解析 布 莱 叶 育 文 吧 ， 首 先 看 看 基本 的 小 写字 母 表 。 


各 多 二 名 和 = 乔 雪 是 委 三， :人 MW 
和 + "@ 多" Ss 二 雪 外、 妇 直 


各“ bd 二 往生 看 “ 佑 名 和 性 bd :人 
ee 项 和 :者 多 ， 元 多 1 志 志 才 
和 bd 昌 Ss 入 者 如“ 和 bd 名- 
k 1 m n O P q r S t 
bd 三 “ 和 雪夫 全 : 
本 "ee » % 
| 名 大 [二 4 生 鲁 生生 
u Y x y z 


例如 ， 


注意 ， 


用 一 个 大 的 空格 ( 实际 上 是 没有 凸 点 的 点 码 单 元 ) 


这 就 是 路 易 斯 . 布 莱 叶 制订 的 布 莱 叶 盲文 
布 莱 时 还 制订 了 表示 重 
这 个 字母 的 编码 ， 因 为 在 传统 的 法 


词组 “you and; 


3 布 芋 叶 盲文 与 二 0 


me” 用 布 莱 叶 盲文 表示 成 如 下 组 合 
妆 人 。 委 才 风光 好 千 鸭 
+ 业 和 。- 2 和 »» 
种 闹 党 牧夫 | PA 
一 个 单词 中 每 个 字母 所 对 应 的 点 码 单元 之 间 都 小 块 空白 分 开 ; 而 单词 之 间 则 
所 分 隔 开 来 。 
的 基本 规范 ， 至 少 它 对 于 拉丁 字母 很 适用 。 
音符 号 字母 的 编码 , 这 在 法 语 中 要 经 常 要 用 到 。 注意 这 里 没有 “w” 
语 中 不 会 用 到 它 ( 别 担心 ， 这 个 字母 最 后 会 出 现 的 ， 


下 文 将 作 讲 解 ) 到 此 为 止 ，64 个 码 字 中 只 使 用 了 25 个 。 


发 现 ， 从 我 们 列举 


经 过 仔细 的 检查 ， 你 会 
表 ) 中 ， 可 以 总 结 出 一 个 规 和 
点 一 第 1 


EE。 第 一 排 (字母 a 到 j) 只 
、2、4 和 5 点 。 第 二 排 在 复 用 了 第 一 排 
第 三 排 也 沿用 了 同 档 


的 编码 的 基 
的 规律 ， 只 是 将 第 3 和 6 点 改 为 四 点 。 


的 那个 三 排 布 莱 叶 盲文 的 例子 小写 字母 


自从 路 易 斯 : 布 莱 叶 发 明 布 莱 叶 育 文 以 来 ， 
文 出 版 物 中 最 常用 的 
使 用 了 很 多 缩写 ， 以 便于 保存 树 型 结 


现 ， 它 们 就 表示 一 个 普通 的 单 
了 这 些 单词 的 码 字 。 
Pe 和 - Ss Se 
, 过 ， Pe 
{none) but Can do 
1 FE 2 en 
a " = ， 者 
各 + 大 E [ 
knowledge fike more not 
FW @. 9 
名 - a + 
全 多 bo 夺 鲁 【二 
US Very 这 you 


{RY | 


二 构 和 提高 阅读 速度 。 例 如 ， 如 3 
词 。 以 下 三 排 图 样 (包含 “ 完 


已 经 扩展 到 各 个 领域 。 
盲文 系统 被 称 为 二 级 布 莱 叶 盲文 (Grade 2 Braille )。 二 级 布 莱 叶 育 


用 到 了 点 码 单 元 中 最 上 面 的 四 个 
础 上 ， 把 第 3 点 改 为 凸 点 。 


目前 在 


三 可 大 
"地 L 
every from 
Li 二 二 
2 .. 
er- 三， 
(none) people 
S De 
.、 
人 是 六 争 

as and 


Bnd Dad 
种 委 犁 各 
gO have 
Ded 二 “> 
各 三 【a 
@" 全 * 
quite rather 
[ad ba 
Da 得 各 
二 竹 和 大 
for of 


因此 ,短语 “you and me” 使 用 二 级 布 莱 叶 盲文 就 可 以 表示 为 : 


+ 区 
本 


(none) 


字母 的 码 字 单 独 出 
整 的 ”第 三 排 ) 为 我 人 


] 展 示 


一 十 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 


到 目前 为 止 , 我 们 已 经 描述 了 31 个 码 字 一 一 单词 问 的 大 空格 〈《 即 没有 吓 点 的 点 码 单 
元 ) 以 及 总 共 3 排 每 排 10 个 的 字母 和 单词 码 字 。 与 理论 上 可 以 达到 的 最 多 码 字 数 一 一 64 相 


比 ， 我 们 还 差 得 远 呢 。 正 如 从 下 面 的 分 析 中 我 们 将 看 到 的 那样 ， 在 二 级 布 莱 叶 盲文 里 


有 任何 的 码 字 会 被 浪费 。 


没 


= 二 和 


首先 , 我 们 可 以 使 用 字母 a 到 j 的 码 字 加 6 号 凸 点 的 组 合 。 这 些 新 码 字 通 常用 来 表示 


单词 中 字母 捉 的 缩写 ， 


还 有 我 们 前 面 所 担心 的 w 字母 〈 像 上 文 的 二 级 布 莱 叶 言 文 单词 编 


码 一 样 ， 表 示 w 字母 的 编码 也 可 以 表示 一 个 单词 )。 


i 
ch gh sh th wh ed er OU OW Ww 
{will ) 
例如 ,单词 “about” 使 用 二 级 布 莱 叶 盲文 可 以 记 作 : 
SG: ': @', :@ 
， 和 和 志 委 参 
“和 和， 
然后 , 我 们 取 从 a 到 j 的 码 字 ,“ 降 低 ” 它 们 使 用 的 点 位 ， 只 用 到 编号 为 2、3、5 和 6 


的 点 ， 这 样 就 得 到 了 新 的 码 字 。 根 据 上 下 文 环境 


， 它 们 将 被 用 来 表示 一 些 标点 符号 或 者 


字符 申 缩 写 。 
. .. s0 ee . on en @ . .人 
要 名 全 "” 生 bb 全 三 外 名 . 志 合 
ea bb te dis en to 5 his in Was 
; : ! 人 ” 
前 4 个 码 字 分 别 表示 逗号 、 分 号 、 冒 号 和 句号 。 需 要 注意 的 是 ， 左 右 括号 使 用 的 是 


相同 的 码 字 ， 但 是 开 闭 引号 使 用 的 却 是 不 同 的 码 字 。 


目前 为 止 我 们 已 经 定义 了 51 个 码 字 了 。“ 占 


组 没有 被 定义 ， 下 面 


写 和 其 他 的 标点 符号 。 


生 的 6 组 就 是 这 些 被 遗漏 的 码 字 ， 我 们 也 | 


占用 3、4、5 和 6 号 点 ”的 码 字 还 有 很 多 


示 一 些 字 符 串 缩 


用 它们 来 


负 " S 二 
二 四 . 
者 [a 者 二 Di 生 生生 
st ing ble af com 


表示 字符 囊 缩 写 “ble” 的 码 字 很 重要 ， 因 为 当 它 不 是 用 来 作为 单词 的 一 部 分 时 ， 它 
的 出 现 就 意味 着 之 后 的 码 字 应 被 译 为 数字 。 表示 数 字 的 码 字 与 表示 字母 a 到 j 的 码 字 是 相 


s. . we ee .. ee se . 和 . 
: 所 - - . 要 be bP 人 DP 
1 2 3 4 5 6 7 8 9 0 


因此 ， 下 面 这 组 编码 : 


表示 的 就 是 数字 256。 
如 果 你 还 要 继续 下 去 ,那么 我 们 还 需要 定义 7 个 码 字 才 算 完全 用 满 原 有 的 64 个 码 字 。 
它们 是 : 


名 
DR 
电 


，， 
SE » 
"和 "SB 


第 一 个 码 字 (4 号 点 凸 起 ) 用 来 表示 音调 符号 (accent indicator )。 其 他 的 码 字 则 用 来 表示 

缩写 的 前 缀 或 者 其 他 的 功能 : 4 号 和 6 号 点 上 山 起 的 码 字 (上 表 的 第 5 个 码 字 ), 根据 上 下 

文 用 来 表示 小 数 点 或 者 强调 符号 (emphasis indicator )。5 号 和 6 号 点 凸 起 的 编码 ， 表 示 与 
“数字 标识 符 ” 相 对 应 的 “字母 标识 符 ”( letter indicator )。 


最 后 《如果 你 现在 还 为 布 莱 叶 盲文 如 何 表示 大 写字 母 忱 心 名 促 的 话 ), 我 们 还 有 6 号 
凸 点 一 一 大 写 标识 符 。 这 个 符号 表示 它 之 后 的 字母 将 都 被 译 为 大 写 。 例 如 , 我们 可 以 把 这 
套 文字 系统 的 原创 者 的 名 字 记 做 : 


入 Dd bd : 入 入 :多 全 
-和 时 | 和 、 + 带 希 *，， 万 二， 鳞 ， 等 
和 1 明生 


这 串 编 码 分 别 表 示 了 一 个 大 写字 母 标识 符 、 字 母 1、 缩 写字 符 串 ou、 字 母 1 和 s， 以 
及 一 个 空格 , 再 加 一 个 大 写字 母 标识 符 , 还 有 字母 b、r、a、i、1、1 和 e。( 在 实际 应 用 中 ， 


TT 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


! 
i 


可 能 会 把 名 字 未 尾 不 发 音 的 2 个 字母 省 略 掉 ， 以 进一步 压缩 编码 ) 


综 上 所 述 ， 我 们 将 6 位 二 进 制 码 (其 实 是 6 个 点 ) 所 能 表示 的 全 部 64 种 可 能 的 编码 
都 罗列 了 一 遍 。 而 且 这 64 组 编码 中 有 很 大 一 部 分 ， 根据 上 下 文 的 不 同 将 有 着 双重 身份 。 
尤其 值得 注意 的 是 数字 标识 符 和 取消 “数字 标识 状态 ”的 字母 标识 符 。 它 们 改变 了 后 面 
编码 的 意义 一 一 从 表示 字母 到 表示 数字 , 又 从 表示 数字 回 到 表示 字母 。 像 这 样 的 编码 通常 
被 称 作 “优先 码 ”( precedence codes ) 或 者 “ 换 档 码 ”( shift codes )。 它 们 改变 着 作用 域内 
编码 的 含义 ， 直 到 作用 域 结束 。 


大 写字 母 标识 符 表 示 紧 随 它 的 字母 〈 而且 仅 仅 是 紧 随 它 的 字母 ) 应 该 被 译 为 大 写 。 
类 似 这 样 的 编码 被 称 为 “逃逸 码 ”( escape codes )。 逃 逸 码 让 你 “逃离 ”对 编码 串 单调 的 、 
一 成 不 变 的 解析 ， 而 转 入 一 种 新 的 解析 方式 中 。 在 以 后 的 章节 中 我 们 将 看 到 ， 在 使 用 二 
进 制 码 对 书面 语言 进行 编码 时 ， 换 档 码 和 逃逸 码 是 相当 常见 的 。 


bs 20 


| | 


Se 


”手电 简 的 剖析 


手电 简 的 应 用 是 极其 广泛 的 ， 例 如 它 可 以 帮助 人 们 在 背光 的 环境 下 阅读 ， 也 可 以 用 
于 发 送 编码 后 的 信息 ， 这 只 是 其 中 最 显而易见 的 两 个 功能 。 普 通 的 家 用 手电 简 ， 还 可 以 
作为 科普 教育 中 的 重要 道具 ， 引 导 人 们 走 进 神秘 的 电 的 世界 。 


电 是 一 种 神奇 的 现象 。 尽 管 电 已 经 被 普遍 地 应 用 到 各 个 领域 中 ， 但 当 人 类 自豪 地 宣 
称 已 经 理解 了 电 的 工作 机 制 时 ， 真 实情 况 是 ， 关 于 电 仍 存在 着 大 量 的 未 解 之 恋 。 但 是 ， 
在 本 书 中 恐怕 我 们 无 论 如 何 都 得 仔细 钻研 一 下 电学 了 ， 幸 好 ， 我 们 只 需要 一 点 基本 概念 
就 可 以 理解 电 在 计算 机 中 的 工作 原理 。 

手电 简 无 疑 是 大 多 数 家 庭 里 最 简单 的 家 用 电器 。 拆 开 一 个 标准 的 手电 简 ， 你 会 发 现 
里 面 有 一 对 电池 、 一 个 灯泡 、 一 个 开关 、 一 些 金属 片 ， 还 有 一 个 可 以 容纳 这 些 元 件 的 塑 
料 外 壳 。 

你 只 需要 电池 和 灯泡 就 可 以 自己 来 做 一 个 简单 的 手电 简 了 。 当 然 ， 你 还 需要 一 些 短 
的 绝缘 导线 (末端 剥 去 绝缘 皮 )， 此 外 你 还 必须 把 这 些 元 件 连 接 起 来 ， 如 下 图 所 示 。 
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编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


注意 ， 在 上 图 的 右边 ， 我 们 可 以 看 到 两 个 断 开 的 线头 ， 那 就 是 开关 。 假 设 这 两 个 电 
池 没 有 问题 ,灯泡 也 没有 烧 坏 ， 让 这 两 个 线头 互相 接触 ， 就 可 以 点 亮 灯泡 。 


刚刚 完成 的 就 是 一 个 简单 的 电路 。 首 先 要 注意 的 是 ,一 个 电路 就 是 一 个 环 路 。 只 有 
从 电池 到 导线 ,再 到 灯泡 和 开关 ， 然 后 再 通过 导线 回 到 电池 的 整个 回路 是 连通 的 ， 灯泡 
才能 被 点 亮 。 电 路 中 出 现任 何 的 中 断 都 将 使 灯泡 无 法 正常 发 光 。 开 关 的 作用 就 是 控制 这 
个 断 开 的 过 程 。 


电路 这 种 环 状 回路 的 特性 说 明 电 路 中 有 某 种 东西 在 循环 流动 ， 或 许 有 些 像 水 流 过 水 
管 那样 。“ 水 和 水 管 ”这 个 比喻 经 常 被 用 来 解释 电流 工作 的 原理 ， 但 是 这 种 模型 就 如 同 所 
有 其 他 的 类 比 一 样 最 终 也 无 法 自圆其说 。 在 茫茫 宇宙 中 ， 电 不 同 于 任何 其 他 的 事物 ， 我 
们 必须 用 它 的 术语 来 解释 它 。 


研究 电流 工作 原理 的 、 最 主流 的 科学 理论 叫做 “电子 理论 ”( electron theory )， 这 套 
理论 认为 电流 是 由 电子 的 运动 而 产生 的 。 


众所周知 ， 所 有 的 物质 一 我们 所 能 看 到 和 感觉 到 的 事物 一 一 (通常 情况 下 ) 都 是 由 
叫做 原子 〈atom ) 的 极其 微小 的 东西 组 成 的 。 每 一 个 原子 又 由 三 种 粒子 构成 : 它们 分 别 是 
中 子 (neutron )、 质 子 (proton ) 和 电子 〈electron )。 你 可 以 把 原子 的 结构 画 成 一 个 小 太阳 
系 ， 其 中 中 子 和 质子 被 束缚 在 原子 核 内 ， 而 电子 则 围绕 着 原子 核 旋 转 ， 犹 如 行星 围绕 太阳 
旋转 一 样 。 


4 二 


i 


我 要 提醒 大 家 的 是 ， 如 果 你 能 搞 到 一 个 放大 倍数 很 大 的 显微镜 足以 看 清原 子 结 构 的 
时 候 ， 你 会 发 现 这 张 图 与 原子 实际 的 样子 并 不 一 样 。 但 是 我 们 可 以 把 它 当 做 一 个 研究 模 
型 ， 方便 我 们 进行 一 些 探 讨 。 


上 图 所 表示 的 原子 包含 有 3 个 电子 、3 个 质子 和 4 个 中 子 ， 这 表明 它 是 一 个 锂 原子 。 
锂 是 112 种 已 知 元 素 之 一 ， 这 些 元 素 都 有 一 个 1 到 112 之 间 的 特定 原子 序数 (atomic 
number )。 原 子 序数 表明 了 这 种 元 素 一 个 原子 的 原子 核 中 所 含 的 质子 数 , (通常 ) 同时 也 
是 一 个 原子 所 含 的 电子 数 。 锂 的 原子 序数 是 3。 


原子 之 间 可 以 通过 化 学 的 方式 结合 形成 分 子 ( molecules )。 分 子 的 性 质 通常 与 组 成 它 
的 原子 大 相 径 庭 。 例 如 ， 水 是 由 水 分 子 组 成 的 ， 每 个 水 分 子 由 两 个 氢 原 子 和 一 个 氧 原子 
( 即 H2O ) 构成 。 很 明显 ,水 跟 毛 气 或 挟 气 都 是 截然 不 同 的 。 同 样 ， 食 盐 的 分 子 是 由 钠 原 
子 和 和 氧 原子 构成 的 ， 显 然 这 丙种 东西 都 没 法 让 我 们 的 炸 昔 条 变 得 更 加 可 口 。 


氨 、 氧 、 钠 和 和 氧 都 是 元 素 。 水 和 盐 都 是 化 合 物 〈compound )。 不 过 盐水 是 混合 物 
( mixture ) 而 不 是 化 合 物 ， 因 为 水 和 盐 都 各 自 保留 着 它们 自己 的 性 质 。 


个 原子 中 电子 的 数目 一 般 情 况 下 与 质子 数目 相同 。 但 是 在 某 些 情况 下 ， 电 子 可 能 
从 原子 中 脱离 。 这 就 是 电流 产生 的 原因 。 


电子 ( electron ) 和 电 ( electricity ) 这 两 个 单词 都 是 起 源 于 古 希 腊 文 “mnXektpov 
(elektron 六 ， 关 于 这 个 词 ， 你 可 能 会 猜测 它 是 表示 “微小 而 又 无 形 的 东西 ”之 类 的 意思 。 
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编码 ~ 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


| 


但 是 事实 并 非 如 此 一 -mekrpovy 的 意思 是 “琥珀 (amber ”， 它 是 树 的 汁液 硬化 后 变 成 的 
一 种 玻璃 状 固体 。 这 两 种 风 马 牛 不 相 及 的 东西 会 被 联系 到 一 起 的 原因 源 于 十 希腊 人 所 进 
行 的 试验 ， 他 们 曾经 通过 政 珀 摩擦 羊毛 ， 产 生 了 我 们 称 之 为 “静电 ”的 东西 。 用 琥珀 在 
羊毛 上 摩擦 使 得 羊毛 掠夺 了 琥珀 的 部 分 电子 。 结 果 羊 毛 会 因为 电子 数 超 过 了 质子 数 而 卷 
曲 ， 而 琥珀 的 电子 数 比 质 子 少 了 。 后 来 在 现代 的 其 他 一 些 实验 中 ， 人 们 发 现 ， 毛 毯 也 可 
以 从 我 们 的 鞋底 中 带 走 电子 。 


质子 和 电子 都 具有 带电 荷 (charge ) 的 性 质 。 质 子 有 一 个 正 电荷 (+ )， 电 子 有 -一 个 负 
电荷 (- )。 中 子 是 中 性 的 , 因而 不 带电 荷 。 尽 管 我 们 使 用 了 加 号 和 减 号 来 标识 质子 和 电子 ， 
但 是 其 实 这 些 符号 并 不 带 有 任何 的 数学 方面 的 含义 ， 也 就 是 不 能 说 明 质子 拥有 电子 所 没 
有 的 性 质 。 使 用 这 些 符 号 仅仅 表示 质子 和 电子 在 某 个 方面 上 的 性 质 是 相反 的 。 这 个 相反 
的 特性 也 正 表明 了 质子 和 电子 是 相互 关联 的 。 


当 质 子 和 电子 在 相同 数目 的 条 件 下 共存 时 ， 它 们 都 处 于 最 和 谐 、 最 稳定 的 状态 。 如 
果 质 子 和 电子 之 间 出 现 失衡 现象 ， 它 们 就 会 试图 进行 自我 修复 。 当 地 毯 偷偷 摸 摸 地 从 你 
的 鞋子 上 挖 走 电子 后 ， 一 切 会 在 你 触摸 到 一 些 东西 而 感到 被 电 了 一 下 时 ， 又 回归 到 平衡 
状态 。 静 电 火 花 是 电子 运动 引起 的 ,是 电子 通过 一 个 回路 一 从 地 毯 传 到 你 的 身体 ,再 回 
到 鞋子 中 的 过 程 所 造成 的 。 


质子 和 电子 之 间 的 关系 还 可 以 这 样 描述 ， 就 是 异性 电荷 相 吸 引 ， 同 性 电荷 相 斥 。 不 
过 关于 这 一 点 ， 我 们 仅仅 靠 观察 原子 结构 图 是 观察 不 出 来 的 。 原 子 核 中 的 质子 被 一 种 力 
量 束缚 到 一 起 , 这 种 引力 要 强 过 同性 电荷 之 间 的 斥 力 , 我 们 称 之 为 “强力 ”( strong force )。 
强力 有 可 能 会 引起 原子 核 的 分 裂 ， 而 核能 就 是 由 此 产生 的 。 在 本 章 中 ， 我 们 仅仅 讨论 通 
过 电子 得 失 来 获得 电能 的 问题 。 


静电 不 仅仅 存在 于 手 触摸 门 把 手 时 产生 的 小 小 火花 中 。 在 风暴 中 ， 底 层 的 云 积聚 了 
大 量 电 子 而 顶端 的 云 失去 电子 ; 最 后 ， 一 道 闪 串 划 破 长 空 ， 使 这 一 切 又 回 到 平衡 。 闪 电 
是 大 量 电子 从 一 端 快速 地 移动 到 另 一端 所 形成 的 。 


手电 简 电 路 中 的 电流 显然 要 比 火 花 或 者 内 电 更 容易 驾驭 得 多 。 灯 泡 之 所 以 能 稳定 而 
持续 地 发 光 ， 是 因为 电子 并 不 是 简单 地 只 是 从 一 点 跳 到 另 一 点 。 电 路 中 ， 某 原子 所 含有 
的 一 个 电子 逃逸 到 它 相 邻 的 下 一 个 原子 中 ， 与 此 同时 ， 这 个 原子 又 从 相 邻 的 上 一 个 原子 
中 获取 一 个 电子 ， 而 失去 电子 的 原子 又 会 从 与 其 相 邻 的 一 个 原子 获得 电子 ， 如 此 循环 。 
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电路 中 的 电子 不 断 地 从 一 个 原子 移动 到 下 一 个 原子 ， 就 形成 了 电流 。 


这 一 切 都 不 是 自发 产生 的 。 我 们 不 能 仅仅 只 把 一 堆 破 旧 的 电路 材料 随便 连接 起 来 后 
就 开始 祈求 电流 的 出 现 。 我 们 需要 一 种 设备 来 促成 电路 中 电子 的 流动 。 回 头 再 分 析 一 下 
前 面 所 画 的 简单 手电 简 的 线路 图 ， 我 想 我 们 能 很 有 把 握 地 断定 ， 使 电子 流动 的 既 不 是 导 
线 ， 也 不 是 灯泡 ， 那 么 或 许 这 个 关键 的 设备 就 是 电池 。 


关于 手电 简 中 用 到 的 电池 类 型 ， 大 部 分 人 应 该 都 有 所 了 解 。 


s 它们 是 简 状 的 ， 并且 有 不 同 的 大 小 ， 例 如 DD、C、A、AA 和 AAA 等 型 号 。 
s 无 论 电 池 的 大 小 如 何 ， 都 标 有 “1.5 伏 ”。 


s 电池 的 一 端 是 平 的 ， 标 有 一 个 负 号 〈- ) 另 一 端 有 一 个 小 的 四起， 并 标 有 一 个 正 
号 (+)。 

# 如 果 你 想 电器 正常 工作 的 话 ， 装 电池 的 时 候 ， 就 要 注意 让 它 的 “+” 端 朝 着 正确 的 
方向 。 


s 电池 的 电能 终 将 被 用 尽 。 有 些 电 池 可 以 进行 再 次 充电 ,但 是 有 些 却 不 可 以 。 
s* 最 后 ,我 们 猜测 ， 通 过 菜 种 很 神奇 的 方式 ， 电 池 能 够 自己 产生 
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所 有 电池 的 内 部 都 会 发 生化 学 反应 ， 也 就 是 说 一 些 分 子 被 分 裂 形成 其 他 的 分 子 ， 或 
者 分 子 间 互 相 结合 形成 了 新 分 子 。 电 池内 的 化 学 物质 是 经 过 研究 精心 选择 的 ， 它 们 之 间 
的 化 学 反应 能 够 使 多 余 的 自由 电子 聚集 到 标 负 号 “- ”的 那 端 〈 称 为 负极 或 者 阴极 )， 而 
在 标 有 正 号 “+” 的 那 端 〈《 称 为 正极 或 者 阳极 ) 则 变 得 急需 额外 的 电子 。 于 是 ， 化 学 能 就 
被 转化 成 了 电能 。 


这 种 化 学 反应 不 会 一 直 进行 下 去 ， 除 非 我 们 有 办 法 能 使 负极 多 余 的 自由 电子 回 到 正 
极 去 。 因 此 如 果 我 们 没有 给 电池 连 上 任何 东西 ， 什 么 事情 也 不 会 发 生 〈 实 际 上 电池 内 仍 
有 化 学 反应 发 生 , 但 是 非常 缓慢 )。 电 路 可 以 将 负极 的 电子 带 走 ， 以 补充 正极 缺失 的 电子 ， 
只 有 当 存 在 电路 的 时 候 ， 化 学 反应 才 会 发 生 。 如 下 图 所 示 ， 电 子 在 电路 中 的 这 次 旅行 是 
沿 逆 时 针 方 向 的 。 
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在 本 书 中 ,红色 ' 用 来 表示 在 导线 中 有 电流 经 过 。 


如 果 不 是 基于 这 样 一 个 简单 的 事实 一 一 所 有 的 电子 ,不管 它们 在 哪里 ， 都 是 完全 一 
样 的， 或 许 电 池内 化 学 物质 中 的 电子 就 无 法 如 此 自由 地 与 铜 导线 中 的 电子 混合 在 一 起 。 
铜 的 电子 与 其 他 物质 的 电子 没有 任何 差别 。 


注意 ， 所 有 的 电池 都 是 按 相 同方 向 放置 的 。 下 面 的 电池 的 正极 ， 从 上 面 电 池 的 负极 
获得 电子 。 就 好 像 两 个 电池 组 合成 了 一 块 更 大 的 电池 ， 它 的 正 负 极 分 别 在 两 块 小 电池 的 
两 端 上 。 组 合 后 的 电池 不 再 是 1.5 伏 ， 而 是 3 伏 。 


如 果 我 们 把 电池 组 中 的 一 块 电 池 倒 置 ， 电 路 就 不 能 工作 了 。 


两 个 电池 的 正极 都 要 为 化 学 反应 提供 电子 , 但 是 由 于 这 两 个 正极 相互 接触 ， 电 子 根 
本 无 法 通过 某 种 途径 到 达 它 们 。 如 果 两 个 电池 的 正极 连 到 了 一 起 的 话 ， 它 们 的 负极 也 应 
该 连 在 一 起 ， 如 下 图 所 示 。 


1 由 于 黑白 印刷 的 原因 ， 在 书 中 红色 只 能 显示 为 淡 灰 色 。 一 一 译 者 注 
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现在 电路 能 够 正常 工作 了 。 与 前 文 我 们 提 到 的 “串联 ”方式 不 同 ， 这 种 连接 电池 的 
方式 被 称 做 “并 联 "。 并 联 后 的 电压 是 1.5 伏 ， 与 每 个 电池 的 电压 是 一 样 的 。 或 许 灯 泡 仍 
能 发 光 ， 但 是 肯定 没有 串联 电池 的 灯泡 亮 。 不 过 电池 的 使 用 寿命 也 将 延长 一 倍 。 


一 般 情况 下 ， 我 们 认为 电池 为 电路 提供 了 电能 。 但 是 我 们 也 同样 可 以 有 反 过 来 想 ， 电 
路 为 电池 内 的 化 学 反应 的 进行 提供 了 条 件 。 电 路 把 电子 从 电池 的 负极 运 走 ， 然 后 转移 到 
电池 的 正极 。 电 池 中 的 化 学 反应 将 持续 进行 ， 直 到 所 有 的 化 学 物质 被 消耗 完 ， 那 时 你 就 
可 以 把 电池 殷 掉 或 者 重新 给 它 充 电 了 。 

从 电池 的 负极 到 正极 ， 电子 流 经 了 导线 和 灯泡 。 但 是 为 什么 我 们 需要 导线 呢 ?” 电 流 
不 可 以 直接 被 空气 传导 吗 ? 哦 ， 可 以 说 能 ， 也 可 以 说 不 能 。 电 流 可 以 通过 空气 传导 ( 特 
别 是 潮湿 的 空气 )， 不 然 的 话 我 们 就 看 不 到 内 电 了 。 但 是 电流 也 不 能 轻易 地 穿 过 空气 。 


一 些 物 质 在 导电 能 力 上 要 比 其 他 一 些 物 质 明 显 更 好 一 些 。 元 素 的 导电 能 力 与 它 原子 
内 的 结构 有 关 。 电 子 围 绕 原子 核 运 行 的 轨道 分 为 不 同等 级 ， 我 们 称 其 为 “电子 层 "。 如 果 
原子 在 最 外 电子 层 中 只 含有 1 个 电子 ， 那 么 这 个 电子 很 容易 逃 选 ， 这 就 是 易 导 电 物 质 所 
需 具备 的 特性 。 这 些 物质 对 于 电流 来 说 是 “ 导 通 ”的 ， 因 而 被 称 做 导体 (conductor )。 最 
好 的 导体 是 铜 、 银 和 人 金 。 这 三 种 元 素 位 于 元 素 周 期 表 的 同一 列 不 是 巧合 。 其 中 铜 是 用 来 
制作 导线 的 最 常见 的 原料 。 


与 导电 性 相反 的 是 阻抗 性 。 有 一 些 物质 与 其 他 的 物质 相 比 更 不 容易 让 电流 通过 ， 我 们 
你 其 为 电阻 。 如 果 一 种 物质 有 着 很 强 的 阻抗 性 一 一 也 就 是 说 它 几 乎 不 能 传导 任何 电流 
它 就 被 称 为 绝缘 体 (insulator )。 橡 胶 和 塑料 都 是 很 好 的 绝缘 体 ， 因 而 它们 经 常 被 用 来 包 
衰 金 属 导 线 。 布 料 和 木头 在 干燥 的 空气 中 也 是 很 好 的 绝缘 体 。 不 过 事实 上 只 要 有 足够 高 
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的 电压 ， 任 何 的 物质 都 是 可 以 导电 的 。 


铜 具有 很 低 的 阻抗 ， 但 实际 上 或 多 或 少 仍然 会 存在 一 点 。 导 线 越 长 ， 它 的 阻抗 就 越 
高 。 如 果 你 用 儿 英 里 长 的 导线 来 为 自制 手电 简 布 线 的 话 ， 导 线 所 产生 的 阻抗 将 变 得 很 高 ， 
以 至 于 手电 简 将 无 法 正常 工作 。 

导线 越 粗 ， 它 的 阻抗 就 越 低 。 这 可 能 有 些 违背 我 们 的 直观 感觉 。 你 可 能 会 想 ， 粗 一 
些 的 导线 需要 更 多 的 电流 来 “ 填 满 它 "。 但 是 实际 上 粗 一 些 的 导线 可 以 使 更 多 的 电子 顺畅 
地 通过 线路 。 

前 面 我 多 次 提 到 了 电压 ， 但 是 却 还 没有 定义 它 。 一 个 电池 有 1.5 伏 的 电压 ， 这 意味 着 
什么 呢 ? 实际 上 ， 电 压 一 一 因 亚 历 山大 伏特 (Alessandro Volta，1745-1827 ) 伯 茵 的 名 字 而 
得 名 ,他 于 1800 年 发 明 出 第 一 枚 电池 一 一 在 初等 电学 中 是 最 难 理解 的 概念 之 一 。 电 压 表征 
了 电流 做 功 的 “ 势 ”( potential )， 也 就 是 电势 能 的 大 小 。 不 管 电池 是 否 被 连接 到 电路 中 ， 
电压 都 是 存在 的 。 


想象 一 块 砖 ， 当 它 在 地 板 上 时 ， 这 块 砖 只 有 很 少 的 势能 。 把 它 从 地 面 上 举 到 离 地板 
四 英尺 的 高 度 ， 现 在 这 块 砖 就 会 有 比较 多 的 势能 。 如 果 你 想 了 解 所 谓 “ 势 能 ”到 底 是 多 
少 ， 把 砖 扔 掉 就 可 以 了 。 当 我 们 拿 着 砖 跑 到 一 座高 楼 的 楼 顶 时 ， 它 的 势能 会 更 多 。 在 这 
三 个 场景 中 ， 你 只 是 拿 着 这 块 砖 ， 它 并 没有 做 什么 ,但 是 这 块 砖 的 势能 却 差别 这 蜡 。 


电学 中 还 有 一 个 比较 简单 的 概念 是 电流 《current )。 电 流 与 流 经 电路 的 电子 数 有 关 。 它 的 
计量 单位 是 安培 ， 这 得 名 于 安 德 烈 . 玛丽 * 安培 ( Andrg Marie Ampere，1775-1836 ), 不 过 
大 家 一 般 简称 这 个 单位 为 “ 安 ”， 例 如 “10 安 的 保险 丝 ”。 假 如 要 获得 1 安 的 电流 ， 你 就 
需要 保证 每 秒 有 6,240,000,000,000,000,000 个 电子 通过 电路 中 的 某 一 点 。 


“水 和 水 管 ”的 这 个 比喻 现在 可 以 帮 你 理解 这 些 概念 : 电流 可 以 看 成 是 水 管 中 流 水 的 
量 。 电 压 可 以 看 做 是 水 压 。 阻 抗 有 些 类 似 水 管 的 宽度 -一 水 管 越 细 ， 阻 抗 越 大 。 所 以 水 压 
越 大 ， 流 经 管子 的 水 也 就 越 多 。 水 管 越 细 ， 水 管 里 流动 的 水 也 就 越 少 。 水 管 中 流 水 的 量 
(相当 于 电流 ) 与 水 压 (相当 于 电压 ) 成 正比 , 与 水 管 的 纤细 程度 ( 相当 于 电阻 ) 成 反比 。 


在 电学 中 , 如果 你 知道 了 电压 和 电阻 ,就 可 以 计算 出 电路 中 的 电流 是 多 少 。 电阻 一 一 
一 般 来 说 物质 部 倾向 于 阻拦 电子 的 通过 一 一 的 单位 是 欧姆 ， 它 得 名 于 乔治 . 西蒙 ' 欧姆 
( George Simon Ohm，1789-1854 )。 著名 的 欧姆 定律 就 是 由 他 提出 的 。 该 定律 可 以 表示 为 : 
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T=E/R 
其 中 ,了 用 来 表示 电路 中 的 电流 ，E 用 来 表示 电压 它 代表 电动 势 )，R 表示 电阻 。 
例如 ， 下 面 这 节 电池 是 单独 放置 的 ， 没 有 连接 任何 设备 。 


它 的 电压 是 1.5 伏 。 它 代表 做 功 的 势能 , 但 是 因为 正 负极 通过 空气 也 有 连通 , 所 以 
电阻 (RK 所 代表 的 物理 量 ) 非常 非常 大 ， 也 就 是 说 ， 电 流 (7) 等 于 1.5 伏 的 电压 除 以 一 个 
极 大 的 数 。 因 而 电流 在 这 里 几 平 是 0。 


现在 我 们 用 一 小 段 铜 线 把 正 负 极 连接 起 来 (从 现在 开始 ， 我 们 不 再 在 示意 图 上 画 寻 
线 的 绝缘 层 )。 


这 种 情形 被 称 为 “短路 ”"。 电 压 仍然 是 1.5 伏 ， 但 是 现在 的 电阻 非常 非常 小 。 现 在 的 电流 
等 于 1.5 伏 的 电压 除 以 一 个 非常 小 的 电阻 值 。 也 就 是 说 电流 将 变 得 非常 非常 大 。 大 量 的 电 
子 流 经 导线 。 在 现实 情况 下 ， 电 流 会 因为 电池 的 型 号 大 小 而 受到 限制 。 电 池 或 许 无 法 导 
通 如 此 大 的 电流 ， 且 实际 电压 也 将 低 于 1.5 伏 。 如 果 电 池 足 够 大 的 话 ， 导 线 将 会 发 热 ， 因 
为 电能 被 转化 成 了 热能 。 如 果 导 线 继续 变 得 很 热 ， 它 将 会 发 光 甚 至 熔化 。 


大 部 分 的 电路 都 介 于 这 两 种 极端 情况 之 间 。 我 们 可 以 把 它们 统一 表述 为 如 下 图 所 示 。 
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上 图 中 的 那 段 折线 对 于 电气 工程 师 来 说 是 表示 电阻 的 符号 。 这 里 我 们 用 它 来 表示 电路 中 
的 电阻 既 不 很 小 也 不 很 大 。 


如 果 导 线 电阻 较 低 的 话 ， 它 将 变 热 并 且 发 光 。 这 就 是 白炽 灯 发 光 的 原理 。 通 常 ， 白 
炽 灯泡 公认 的 发 明 者 是 美国 著名 发 明 家 ,托马斯 . 阿尔 瓦 * 爱迪生 ( Thomas Alva Edison ， 
1847-1931 )， 但 是 这 种 观点 是 在 他 到 得 灯泡 的 专利 之 后 (1879 ) 被 广 为 传 播 的 ， 实 际 上 
在 这 个 领域 很 多 科学 家 都 有 过 研究 。 


灯泡 里 面 有 一 根 很 细 的 金属 丝 ， 我们 称 它 为 灯丝 ， 一 般 情况 下 灯丝 是 用 忽 制 作 的 。 
灯丝 的 一 端 连 在 灯泡 底座 的 凸 起 上 ， 另 一 端 连 到 金属 底座 上 ， 金属 底座 与 凸 起 之 间 被 绝 
缘 层 隔 开 。 人 金属 丝 的 电阻 使 它 开始 发 热 。 如 果 暴 露 在 空气 由 ， 钨 丝 将 达到 燃点 并 开始 燃 
烧 ， 但 是 在 灯泡 的 真空 泡 室内 ， 钨 丝 就 会 发 出 光亮 


大 多 数 普通 手电 简 都 用 2 节 电 池上 串联 成 一 组 ， 总 的 电压 是 3 伏 。 手 电 简 中 一 般 使 用 
电阻 为 4 欧 的 灯泡 。 因 此 ， 电 流 的 大 小 等 于 3 伏 除 以 4 欧 ， 也 就 是 0.75 安 ， 也 可 以 写成 
750 毫 安 。 这 意味 着 每 秒 钟 有 4,680,000,000,000,000,000 个 电子 流 经 灯泡 ( 如 果 使 用 欧姆 
表 对 手电 简 灯 泡 的 电阻 进行 实际 测量 ， 你 将 得 到 一 个 远 远 小 于 4 欧 的 读数 。 这 是 因为 钨 
的 阻抗 与 它 的 温度 有 关 ， 当 灯泡 温度 升 高 并 开始 发 光 时 ， 忽 丝 的 阻抗 也 随 之 增加 )。 


你 或 许 已 经 发 现 ， 买 回 家 的 灯泡 上 都 标 有 一 个 固定 的 瓦特 数 。 瓦 特 这 个 单位 得 名 于 
詹姆斯 . 瓦特 ( James Watt，1736-1819 )， 他 以 对 蒸汽 机 的 研究 而 广为人知 。 瓦 特 是 功率 
(也 ) 的 计量 单位 ， 它 的 计算 公式 如 下 : 
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我 们 的 手电 简 是 3 伏 ，0.75 安 的 ， 这 表明 灯泡 的 功率 应 该 是 2.25 瓦特 。 
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你 家 里 或 许 在 使 用 100 瓦 的 灯泡 。 它 们 被 设计 成 能 在 120 伏 的 电压 下 工作 。 因 此 ， 
流 经 它们 的 电流 的 大 小 等 于 100 瓦 除 以 120 伏 ， 也 就 是 0.83 安 。 所 以 100 瓦 灯 泡 的 电阻 
是 120 伏 除 以 0.83 安 ， 即 144 欧姆 。 


好 了 ， 现在 我 们 貌似 已 经 把 手电 简 里 里 外 外 都 分 析 了 一 遍 一 一 电池 ， 导 线 还 有 灯泡 。 
但 是 ， 我 们 还 忘记 了 最 重要 的 一 部 分 ! 


是 的 , 那 就 是 开关 。 开 关 控 制 电 路 中 电流 是 否 接 通 。 当 开关 被 设置 成 允许 电流 通过 时 ， 
我 们 称 它 的 状态 为 “ 开 ”, 或 者 “闭合 "。 当 处 在 “ 关 ” 或 者 “ 断 开 ”状态 时 ， 开 关 不 允许 电 
流通 过 。(“ 闭 合 ”和 “ 断 开 ”这 两 个 词 ， 在 用 来 描述 开关 时 ， 其 含义 与 用 来 描述 房 门 时 恰好 
是 相反 的 。 一 扇 闭 合 的 门 会 阻止 所 有 试图 穿 过 它 的 东西 ; 一 个 闭合 的 开关 却 可 以 使 电流 导 
通 。) 


开关 只 能 是 闭合 状态 或 断 开 状态 。 电 流 只 能 是 有 或 者 无 。 灯 泡 也 只 能 是 发 光 或 不 发 
光 。 就 像 莫 尔 斯 和 布 菜 叶 发 明 的 二 进 制 码 一 样 ， 这 个 简单 的 手电 简要 人 么 是 开 着 的 ， 要 人 么 
是 关 着 的 。 没 有 介 于 二 者 之 间 的 状态 。 在 后 面 的 章节 中 ， 二 进 制 码 与 电气 电路 之 间 的 这 种 
相似 性 将 起 到 很 大 作用 。 
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你 12 岁 了 。 在 一 个 伤感 的 日 子 里 ， 你 最 好 的 朋友 跟随 家 人 搬 到 别 的 镇 子 。 从 此 以 后 
你 只 能 通过 电话 同 他 交谈 了 。 但 是 电话 交谈 和 深夜 里 用 手电 简 以 莫 尔 斯 码 方法 会 谈 是 
法 相 比 的 。 你 另外 的 一 个 好 朋友 ， 也 就 是 你 的 邻居 ， 现 在 成 了 你 新 的 密友 。 是 时 候 该 教 
给 他 一 些 莫 尔 斯 码 ， 让 深夜 的 手电 简 再 次 为 你 们 闪烁 了 。 


可 是 问题 是 ， 这 位 新 朋友 的 卧室 窗户 和 你 卧室 的 窗户 不 是 对 着 的 。 尽 管 两 栋 房 子 挨 
着 ， 但 是 卧室 窗户 是 朝向 同一 个 方向 的 。 除 非 你 能 想 个 办 法 ， 在 室外 摆 上 一 面 镜子 ， 不 
然 手 电 简 就 不 能 用 来 夜 谈 了 。 


怎么 办 ? 


也 许 现 在 你 已 经 懂得 一 些 关 于 电学 的 知识 了 ， 所 以 你 打算 用 电池 、 灯 泡 、 开 关 和 导 
线 来 自制 一 个 “手电 简 ”"。 在 第 一 次 尝试 中 ， 你 把 电池 还 有 开关 在 卧室 中 接 好 ， 然 后 从 窗 
户 引 出 两 根 导线 ， 绕 过 围墙 ， 接 到 你 朋友 的 革 室 里 ,在 那里 把 它们 接 到 一 个 灯泡 上 。 


m 
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你 的 房子 您 盟友 的 房子 
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尽管 图 中 只 画 了 一 节 电 池 ， 不 过 实际 应 用 中 


你 也 许 要 用 两 个 。 在 以 后 的 示意 图 中 ， 
下 面 的 标志 表示 一 个 “ 关 ” 状 态 (也 称 断 天 


状态 ) 的 开关 。 


es 


下 图 则 表示 开关 是 “ 开 ” 的 (也 称 作 闭 合 状态 )。 


一 一 


本 章 手电 简 跟 上 一 革 中 的 手电 简 的 工作 方式 一 样 ， 尽 管 本 章 的 手电 简 中 用 来 连接 各 
个 部 件 的 导线 比 原来 长 了 不 少 。 当 你 把 自己 房间 那 端 的 开关 闭合 时 ， 你 朋友 那儿 的 灯泡 
就 会 被 点 亮 。 
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你 的 鹤 子 


现在 ， 你 可 以 用 莫 尔 斯 码 来 发 信息 了 。 0 “手电 简 ”， 
就 可 以 照样 再 安装 男 一 套 这 样 的 “ 远 距离 ”设备 ， 好 让 你 的 朋友 也 能 


_ 多 | 加 


你 朋友 的 房子 


你 


给 你 发 信息 SN 


你 的 房子 


恭喜 你 ! 你 已 经 架设 好 了 一 套 双 向 电报 系统 ! 你 可 能 注意 到 了 ， 这 个 系统 包含 了 两 
个 相互 独立 但 又 完全 相同 的 电路 。 理 论 上 来 说 ， 在 你 给 朋友 发 送信 息 的 同时 ， 他 也 可 以 
给 你 发 信息 〈 不 过 同时 阅读 和 发 送 电码 对 你 的 大 脑 来 说 或 许 是 个 挑战 )。 


聪明 的 你 也 许可 以 采 月 


有 如 下 方式 把 这 套 系统 加 以 改进 ， 这 样 可 以 节省 25% 的 导线 。 


J 


Ps 


爷 的 房子 标 朋 友 的 房子 
注意 ， 现 在 这 两 个 电池 的 负极 被 连 在 一 起 。 但 是 这 两 个 回路 (电池 到 开关 到 灯泡 再 
到 电池 ) 依然 是 相互 独立 的 ， 尽 管 现 在 它们 看 起 来 像 连 体 婴 儿 一 样 。 


| 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


这 种 接线 方式 被 称 为 公用 连接 (common )。 这 个 电路 的 公用 部 分 ， 从 最 左 端的 灯泡 
和 电池 的 连接 点 开始 ， 到 最 右 端 的 灯泡 与 电池 的 连接 处 结束 。 我 们 在 图 中 用 两 个 小 圆 点 
把 这 部 分 连 线 标示 了 出 来 。 


我 们 来 进一步 检查 一 下 这 个 电路 ， 以 确保 使 用 时 不 会 有 意外 发 生 。 首 先 ， 当 你 在 自 
己 这 端 闭合 开关 的 时 候 ， 你 朋友 屋 里 的 灯泡 就 会 点 亮 。 红 色 的 线 表 示 出 了 电路 中 电流 流 
动 的 路 径 。 


你 的 房子 你 朋友 的 房子 
电路 的 其 余部 分 没有 电流 通过 ， 因 为 没有 完整 路 径 可 以 让 电子 构成 回路 。 


当 你 没有 发 送信 息 ， 而 你 的 朋友 正在 发 送 时 ， 他 房间 里 的 开关 控制 了 你 房间 里 灯泡 
亮 灭 。 下 图 的 红线 仍然 表示 电流 流 经 的 路 径 。 
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| 
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你 朋友 的 房子 


当 你 和 你 的 朋友 同时 发 送信 息 时 ， 有 时 两 个 开关 都 断 开 了 ， 有 时 一 个 闭合 而 另 一 个 
断 开 ， 也 有 可 能 两 个 开关 同时 闭合 。 最 后 一 种 情况 下 ， 电 路 中 电流 的 示意 图 如 下 图 所 示 。 
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你 朋友 的 房子 


电路 的 公用 部 分 没有 电流 通过 。 


我 们 通过 公用 线路 把 两 个 电路 合成 了 一 条 电路 。 通 过 这 种 方式 ， 把 连通 两 栋 房 子 所 
需 的 导线 从 4 根 减 少 到 了 3 根 ， 节 约 了 25% 的 导线 。 


如 果 整 个 系统 必须 铺设 很 长 的 线路 ， 可 能 还 得 绞 尽 脑汁 再 削减 一 根 导线 以 进一步 而 
约 开支 。 遗憾 的 是 , 对 于 眼前 这 套 使 用 1.5 伏 干电池 和 小 灯泡 的 系统 来 说 , 这 是 不 可 行 的 。 
但 如 果 我 们 把 它们 换 成 100 伏 的 电池 和 大 得 多 的 灯泡 ， 问 题 就 迎 为 而 解 了 。 


以 下 就 是 解决 的 思路 : 你 不 必 非 得 用 导线 来 完成 电路 的 共用 部 分 ， 你 可 以 用 其 他 的 
东西 来 代替 导线 。 恰 巧 我们 这 儿 有 一 个 现成 的 大 球 ， 你 可 以 用 它 来 代 蔡 。 这 个 大 球 直 径 
近 7900 英里 ， 由 金属 、 岩 石 、 水 ， 以 及 有 机 质 〈 其 中 大 部 分 是 没有 生命 的 ) 组 成 。 我 们 
称 这 个 巨大 球体 为 “地 球 ”。 


上 一 章 里 ， 在 讲 寻 体 的 时 候 提 到 了 银 、 铀 和 金 ， 但 没有 提 过 岩石 层 和 履 盖 层 。 实 际 
上 ， 泥土 并 不 是 一 个 很 好 的 导体 ， 尽 管 有 一 些 泥土 ( 例如 沼泽 ) 的 导电 性 比 其 他 的 ( 例 
如 干 沙 ) 要 好 一 些 。 但 是 我 们 知道 导体 有 一 条 性 质 : 截面 越 大 导电 性 越 好 。 一 条 很 粗 的 
导线 ， 其 导电 性 要 远 远 好 于 一 条 细 导 线 。 这 就 是 地 球 所 拥有 的 优势 。 它 实在 是 太 大 了 。 


要 想 用 地 球 充当 导体 ， 可 不 是 随便 在 西红柿 地 里 插 根 线 那 么 简单 。 你 必须 使 用 跟 地 
蒜 有 充分 接触 的 物体 ， 也 就 是 有 很 大 表面 积 的 导体 。 这 儿 有 个 不 错 的 解决 方案 ， 即 使 用 
一 个 至 少 8 英尺 长 、1/2 英寸 粗 的 铜 柱 电极 。 它 提供 了 与 地 球 150 平方 英寸 的 接触 面积 。 
你 可 以 用 一 个 大 锤子 把 这 个 电极 砸 进 地 里 ， 然 后 在 上 面 接 上 一 根 导线 。 或 者 ， 如 果 你 家 
的 水 管 是 用 铜 做 的 ， 并 且 是 从 屋外 的 地 下 接 过 来 的 ， 那 么 你 可 以 在 水 管 上 接 上 导线 。 

关于 电流 的 接地 ， 在 英国 人 们 称 其 为 “earth” ， 在 美国 叫 “ground”。“ground” 这 个 
词 的 含义 有 一 些 含混 不 清 ， 因 为 它 也 经 常用 来 表示 我 们 前 文中 所 说 的 “公用 电路 ”"。 在 本 
章 中 ， 除 非特 别 指明 , “ground” 都 表示 物理 接地 。 
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一 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


在 电路 图 中 ， 入 们 用 以 下 符号 表示 接地 。 


加 


电气 工程 师 们 一 般 都 会 使 用 这 个 符号 , 因为 他 们 不 喜欢 花 时 间 去 描画 一 个 被 埋 在 地 下 的 8 
英尺 长 的 铜 柱 。 


我 们 来 看 看 新 的 电路 是 如 何 工作 的 。 先 从 一 个 单 向 的 电路 开始 分 析 。 


i 


挣 的 谎 子 你 朋友 药房 子 


如 果 你 使 用 的 是 高 压 电池 和 大 灯泡 ， 你 只 需要 在 你 和 你 朋友 的 房子 之 间接 一 根 导线 ， 
因为 可 以 把 地 球 当 成 一 条 导线 。 


你 的 房子 你 朋友 的 房子 
当 你 闭合 开关 时 ， 电 流 就 会 按 下 图 流动 。 
| 
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你 的 房子 你 朋友 的 房子 


电子 从 你 朋友 房子 的 地 下 出 发 ， 经 过 灯泡 、 导 线 和 你 房间 的 开关 ， 最 后 回 到 电池 的 
正极 。 而 电子 最 初 是 从 电池 的 负极 传 入 地 下 的 。 
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儿 或 许 还 真 的 很 想 看 到 电子 从 埋 在 你 家 后 院 的 8 英尺 长 的 铜 柱 进入 地 下 ， 然 后 飞速 
通过 大 地 到 达 埋 在 你 朋友 家 后 院 的 铀 柱 的 情景 。 

然而 每 时 每 刻 地 球 都 在 充当 着 全 世界 成 二 上 万 条 电路 的 导线 ， 想 到 这 些 ， 你 可 能 会 
感到 迷茫 : 电子 怎么 知道 它 要 去 什么 地 方 ? 其 实 它们 不 知道 。 换 一 种 描述 地 球 的 模式 或 
许 更 恰当 些 。 

没 错 ， 地 球 是 一 个 巨大 的 导体 ， 但 是 我 们 也 可 以 把 它 看 做 是 电子 的 来 源 和 储藏 库 。 
地 球 之 于 电子 就 恰 如 海洋 之 于 水 滴 。 地 球 是 一 个 近乎 无 尽 的 电子 之 源 ， 同 时 也 是 一 个 无 
比 庞大 的 电子 池 。 

不 过 地 球 还 是 有 一 定 的 电阻 的 。 所 以 当 我 们 使 用 1.5 伏 干电池 和 小 灯泡 时 ,不 能 通过 
接地 来 节约 我 们 所 需 的 线路 开支 。 对 于 低 电 压 电池 而 言 ， 地 球 的 电阻 实在 是 太 高 了 。 

你 可 能 注意 到 ， 前 面 两 框图 中 所 画 的 电池 ， 其 负极 都 接地 了 ， 如 下 图 所 示 。 


以 后 , 我 将 不 再 画 这 个 图 例 了 。 我 将 用 大 写字 母 “V”( 表示 电压 ) 来 代替 它 。 因 此 
单 向 的 灯泡 电报 系统 的 电路 示意 图 就 变 成 了 如 下 这 个 样子 。 


你 的 房子 你 朋友 的 房子 
字母 V 是 电压 的 意思 , 但 是 它 也 有 吸尘器 的 意思 。 我 们 把 V 想象 成 一 个 电子 吸尘器 ， 
然后 把 地 面 想象 成 电子 的 海洋 。 电 子 吸尘器 通过 电路 把 电子 从 地 下 拉 出 来 ， 让 它们 沿 设 
计 好 的 线路 开始 工作 ( 例如 点 亮 灯泡 )。 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
全 Re 


大 地 有 时 也 被 认为 是 零 电 势 ( zero potential ) 点 。 也 就 是 说 现在 没有 电压 。 电 压 


正如 我 之 前 介绍 的 一 一 是 电能 做 功 的 势 , 这 与 其 在 空中 的 砖 所 潜藏 的 势能 是 类 似 的 。 零 电 
势 就 像 放 置 在 地 面 上 的 砖 一样 一 -已 经 没有 空间 可 以 让 它 下 沙 了 。 


在 第 4 章 中 ,我 们 最 初 注意 到 的 儿 个 问题 之 一 便 是 电路 是 一 条 回路 。 不 过 我 们 的 新 
电路 看 起 来 可 不 像 条 回路 。 实 际 上 ， 它 仍然 是 。 你 可 以 使 用 负极 接地 的 电池 来 替换 掉 字 
母 V, 然后 把 所 有 接地 标志 用 线 连 起 来 。 最 后 就 会 得 到 一 张 与 本 章 开始 处 一 模 一 样 的 电路 
图 。 


因此 ， 在 一 对 铜 柱 电极 (或 者 自来水 管 ) 的 帮助 下 ， 我 们 只 用 了 两 根 导线 ， 就 冲破 
了 你 与 你 朋友 家 之 间 围 墙 的 阻隔 ， 构 建 了 一 个 双向 的 莫 尔 斯 码 发 送 系 统 。 
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这 条 电路 在 功能 上 与 之 前 的 那个 电路 是 完全 一 样 的 ， 而 在 之 前 那 条 电路 中 ， 我 们 使 
用 了 3 条 导线 来 穿越 房子 之 间 的 围墙 。 


在 本 章 中 ,我 们 已 在 通信 的 演变 中 迈 出 了 重要 一 步 。 之 前 我 们 使 用 莫 尔 斯 码 交 流 时 ， 
必须 要 在 视线 直 视 的 范围 里 ， 并 且 要 保证 在 手电 简 光 线 可 以 传播 的 距离 之 内 。 


但 是 使 用 导线 ， 我 们 不仅 可 以 构建 出 一 个 可 以 绕 过 拐角 的 、 能 够 在 视线 之 外 的 发 报 
系统 ， 而 且 我 们 自己 再 也 无 需 受 距离 的 限制 。 我 们 可 以 跨越 成 百 上 干 英里 来 进行 通信 ， 
只 需要 铺设 足够 长 的 线路 即 可 。 


不 过 还 有 个 问题 。 尽 管 铜 是 很 好 的 导电 体 ， 但 是 它 也 不 是 完美 的 。 线 路 越 长 ， 它 们 
的 电阻 也 就 越 大 。 电 阻 越 大 ， 线 路 中 的 电流 就 越 少 。 电 流 越 少 ， 灯 泡 就 越 暗 。 


那么 到 底 我 们 可 以 做 出 多 长 的 导线 呢 ? 这 要 依 实际 情况 而 定 。 假 如 我 们 现在 使 用 的 
是 原来 的 4 条 导线 的 双向 电路 ， 而 没有 使 用 接地 和 公用 电路 ， 并 且 还 用 手电 简 电 池 和 人 小 
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灯泡 。 为 了 节约 成 本 ， 也 许 你 先 从 无 线 电 室 ( Radio Shack， 美 国 出 售 电器 的 连锁 店 ) 购 
买 了 一 些 20 号 规格 的 电话 线 , 花费 为 每 100 英尺 9.99 美元 。 电 话 线 一 般 是 用 来 把 扬声器 
连接 到 立体 声音 响 系 统 上 的 。 它 有 两 个 接头 ， 因 而 对 我 们 的 电报 系统 来 说 ， 也 是 个 不 错 
的 选择 。 如 果 你 和 你 朋友 的 卧室 之 间 的 距离 小 于 50 英尺 ， 这 卷 电话 线 就 足够 了 。 


导线 的 粗细 使 用 美国 线 径 标准 ( American Wire Gauge，AWG ) 进行 度量 。AWG 数值 
越 小 ， 导 线 越 粗 ， 电 阻 也 就 越 小 。 你 买 的 20 号 规格 的 电话 线 ， 其 直径 大 约 是 0.032 英寸 ， 
大 约 每 1000 英尺 有 10 欧 的 电阻 ， 也 就 是 说 在 你 们 卧室 间 的 往返 距离 一 一 100 英尺 左右 ， 
大 约 有 1 欧 的 电阻 。 


情况 其 实 不 错 ， 但 是 如 果 我 们 需要 铺设 一 英里 的 线路 呢 ? 导线 的 电阻 将 大 于 100 欧 。 
记得 在 上 一 章 中 提 到 过 ， 我 们 的 小 灯泡 电阻 只 有 4 欧姆 。 根 据 欧 姆 定律 ， 可 以 很 容易 计 
算出 电路 中 的 电流 已 经 不 再 是 0.75 安 了 (3 伏 除 以 4 欧 ), 现在 它 将 变 得 比 0.03 安 还 要 小 
(3 伏 除 以 100 欧 以 上 )。 几乎 可 以 肯定 ， 这 点 电流 不 足以 点 亮 灯 泡 。 


使 用 粕 一 点 的 导线 是 一 个 不 错 的 解决 方案 ,但 是 那 会 比较 昂贵 。10 号 规格 线 (无 线 
电 室 用 来 作为 汽车 耦合 线 出 售 ， 其 价格 为 每 35 英尺 11.99 美元 ， 你 需要 两 倍 的 长 度 ， 因 
为 这 种 导线 只 有 1 个 接口 ) 大 约 有 0.1 英寸 粗 ， 不 过 它 每 1000 英尺 只 有 1 欧 的 阳 抗 ， 也 
就 是 每 英里 5 欧 。 


另 一 种 解决 方案 是 增加 电压 ,使 用 更 大 电阻 的 灯泡 。 例 如 , 一 个 能 够 照 亮 房间 的 100 
瓦 灯泡 ， 是 设计 成 在 120 伏 电压 下 工作 的 ( 美国 市 电 电 压 )， 大 约 有 144 欧 的 电阻 。 导 线 
的 电阻 对 整个 电路 的 影响 将 变 得 小 许多 。 


在 150 年 前 ， 人 们 在 铺设 第 一 个 跨越 美洲 和 欧洲 的 电报 系统 时 ， 这 些 都 是 面临 的 问 
题 。 如 果 忽 视 了 线路 直径 还 有 高 电压 的 因素 ， 电 报 线路 将 完全 无 法 持续 工作 。 根 据 设计 
方案 ， 系 统 距离 跨度 的 极限 是 200 英里 。 这 个 长 度 与 纽约 和 加 利 福 尼 亚 间 数 干 英里 的 距 
离 相 比 ， 还 是 有 很 大 差距 的 。 


这 个 难题 的 解决 方案 一 一 个 是 给 手电 简 的 ， 而 是 给 “ 滴 滴 答 答 ” 的 近代 电报 系统 的 一 一 
尽管 它 只 不 过 是 个 很 简陋 的 装置 , 但 是 正 是 基于 这 个 装置 ， 整个 计算 机 系统 才 被 构建 出 来 。 
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萨 缪 尔 : 芬 利 . 布 里 斯 : 莫 尔 斯 ( Samuel Finley Breese Morse ) 1791 年 出 生 于 马 萨 诸 
塞 州 的 查尔斯 顿 镇 。 这 座 小 镇 兽 是 邦 克 山 战 役 打响 的 地 方 ， 位 于 波士顿 的 东北 部 。 莫 尔 
斯 出 生 那 年 ， 路 美国 宪法 制定 刚 过 两 年 ， 而 当时 乔治 华盛顿 正 处 在 他 的 第 一 个 总 统 任 
期 内 ; 叶 卡 捷 琳 娜 大 帝 正 统治 着 俄国 ， 路 易 十 六 和 玛 莉 - 安 托 瓦 内 特 将 在 2 年 后 的 法 国 
大 革命 中 人 头 落 地 。 然 后 在 1791 年 ,莫扎特 完成 了 他 最 后 一 部 歌剧 一 <《 广 第 XThe Magic 
Flute )， 不 久 后 在 35 岁 时 与 世 长 辞 。 


莫 尔 斯 在 耶鲁 大 学 深造 , 并 在 伦敦 学 习 艺 术 。 后 来 他 成 为 了 一 名 
成 功 的 画家 。 他 的 作品 《 拉 法 耶 特 将 军 》X( General Lafayette, 1852 年 )， 
现在 还 悬挂 在 纽约 市 政大 厅 。1836 年 ， 他 以 独立 候选 人 的 身份 参与 
竞选 纽约 市 市 长 ， 并 获得 了 5.7% 的 选票 。 他 还 是 一 个 早期 的 摄影 爱 

好 者 。 莫 尔 斯 接受 路 易 斯 * 达 盖 尔 (Louis Daguerre ) 的 亲自 指点 ， 
学 习 银 板 照 相 术 , 并 且 拍 摄 了 美国 最 早 的 一 些 银 板 照片 。 在 1840 年 ， 
他 把 这 项 技术 传授 给 了 17 岁 的 马 修 : 布雷 迪 ( Mathew Brady ), 而 布 
起 ， 完 成 了 一 组 非常 有 纪念 意义 的 关于 美国 内 战 、 亚 伯 拉 罕 ， 林肯 


雷 迪 后 来 与 同事 一 
( Abraham Lincoln )， 还 有 萨 缪 尔 . 莫 尔 斯 本 人 等 的 摄影 作品 。 
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但 是 ， 这 些 只 是 他 兼 收 并 曹 职业 生涯 中 的 点 缀 而 已 。 萨 绥 尔 ' 莫 尔 斯 之 所 以 被 现在 
的 人 们 所 熟知 ， 还 是 因为 他 发 明 的 电报 机 ， 以 及 以 他 名 字 命 名 的 电码 。 


全 球 性 即时 通信 对 于 我 们 来 说 已 经 司空 见 惯 了 ， 这 项 技术 其 实 是 在 近代 才 得 到 发 展 
的 。 回 溯 到 19 世纪 早期 ， 你 也 可 以 进行 即时 通信 或 者 远 距 离 通信 ， 但 是 不 能 同时 做 到 这 
两 点 。 即 时 通信 受 声音 传播 距离 的 限制 《没有 扩 音 器 可 以 用 ), 或 者 受 视野 的 限制 (或许 
可 以 使 用 望远镜 作为 辅助 工具 )。 使 用 信件 可 以 进行 更 远 距 离 的 通信 ， 但 是 寄 信 耗费 的 时 
间 太 多 ， 并 且 需 要 马匹 、 火 车 或 轮船 。 


莫 尔 斯 的 发 明 问世 前 的 几 十 年 里 ， 人 们 为 了 提高 远 距 离 通信 的 速度 ， 做 过 很 多 尝试 。 
技术 上 比较 简单 的 方法 是 ， 雇 用 一 些 人 站 在 山上 ， 作 为 中 继 系统 ， 挥 旗 发 出 旗 语 。 而 在 
技术 上 稍 复杂 的 解决 方案 是 ， 使 用 带 有 机 械 臂 的 大 型 装置 ， 代 替 人 做 挥 旗 的 工作 。 


“电报 ”( telegraph, 字面 意思 就 是 “ 远 距 离 书写 ”) 这 个 想法 在 19 世纪 早期 就 出 现 了 ， 
而 且 在 萨 缪 尔 * 莫 尔 斯 1832 年 开始 实验 之 前 ， 其 他 的 发 明 家 就 已 经 开始 研究 它 了 。 理 论 
上 说 来 ， 电 报 机 的 原理 是 很 简单 的 : 在 线路 的 这 一 端 采取 一 些 措 施 ， 使 线路 的 另 一 端 发 
生 某 种 变化 。 这 恰好 与 我 们 上 一 章 中 用 手电 简 远 距离 发 送信 息 所 用 到 的 方法 很 一 致 。 不 
过 呢 ， 莫 尔 斯 先生 不 会 用 灯泡 作为 他 的 信号 发 生 装 置 了 ， 因 为 最 早 的 可 使 用 的 电灯 泡 到 
1879 年 才 被 发 明 出 来 。 作 为 替代 手段 ， 莫 尔 斯 利用 了 电磁 (electromagnetism ) 现象 。 

如 果 你 手头 有 一 根 铁 棒 ， 那 么 在 上 面 用 细 导 线 绕 几 百 圈 ， 然 后 在 导线 上 接 通电 流 ， 


铁 棒 就 变 成 了 一 块 磁铁 。 现 在 它 可 以 吸引 其 他 的 铁 块 和 钢 块 〈 电 磁铁 上 缠绕 足够 多 的 细 
导线 , 会 产生 足够 强 的 电阻 , 能 防止 电磁 铁 产生 短路 现象 ) 断 开 电流 , 铁 棒 将 丧失 磁性 。 


PF 


电磁 铁 是 电报 机 的 基础 。 在 线路 的 一 端 闭合 或 断 开 开 关 ， 可 以 使 线路 男 一 端的 电磁 
铁 有 所 动作 。 


实际 上 ， 莫 尔 斯 的 第 一 个 电报 机 比 后 来 演化 出 的 版 本 要 复杂 。 莫 尔 斯 认为 ， 发 报 系 
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统 应 该 确实 能 在 纸 上 写 出 些 什 么 东西 ， 或 者 就 像 计算 机 用 户 后 来 描述 的 那样 ,，“ 输 出 一 份 
硬 拷 贝 。” 当然 ， 电 报 机 输出 的 不 一 定 非得 是 单词 ， 因 为 那样 做 就 太 过 复杂 了 。 但 是 不 管 
是 杂乱 无 章 的 线条 还 是 点 和 划 ， 在 纸 上 总 应 该 写 些 东西 。 注 意 ， 莫 尔 斯 现在 一 头 扎 进 了 
一 个 需要 纸张 和 阅读 的 模型 ， 这 很 像 拟 伦 本 ' 霍 伊 【Valentin Haiiy ) 的 观点 一 一 盲人 用 的 
书 应 该 印 有 吓 起 的 字母 。 


尽管 萨 缘 尔 : 莫 尔 斯 在 1836 年 通知 过 专利 局 ， 他 成 功 发 明了 电报 机 ,但 是 直到 1843 
年 ,他 才 说 服 美国 国会 ,为 其 创建 了 一 个 公共 基金 。1844 年 5 月 24 日 , 这 是 历史 性 的 一 
天 ， 当 华盛顿 特区 和 马里 兰州 巴尔 迪 摩 市 之 间 的 电报 线路 架设 完成 时 ， 一 条 信息 被 成 功 
地 传递 ， 内 容 是 圣经 中 的 句子 : “What hath God wrought!” 


传统 电报 机 中 用 来 发 送信 息 的 电 键 ， 其 外 形 如 下 图 所 示 。 


它 虽然 外 表 奇特 ， 其 实 只 是 一 个 被 设计 成 有 “最 大 开 闭 速 度 ” 的 开关 而 已 。 如 果 需 
要 长 时 间 使 用 电 键 ， 最 舒适 的 方法 是 ， 用 拇指 ， 食 指 和 中 指 握 住 手柄 ， 轻 击 它 使 其 上 下 
移动 。 保 持 电 键 的 按 下 状态 一 小 段 时 间 ， 就 会 产生 一 个 “点 ”的 莫 尔 斯 码 。 按 下 状态 保 
持 的 时 间 更 长 一 些 就 会 产生 一 个 “ 划 ” 的 莫 尔 斯 码 。 


线路 的 男 一 端 是 一 个 接收 器 ， 它 主要 是 由 一 块 电 磁铁 拉动 一 根 金属 杆 构 成 的 。 最 初 ， 
电磁 铁 控 制 的 是 一 只 钢笔 。 有 一 个 装置 通过 使 用 一 个 压 紧 的 弹簧 来 拉动 一 卷 纸 经 过 设备 ， 
与 电磁 铁 连接 着 的 钢笔 就 会 弹 起 或 落下 ， 在 纸 上 画 出 点 和 划 。 能 读 懂 莫 尔 斯 电码 的 人 员 
就 可 以 把 这 些 “ 点 ”和 “ 划 ” 译 成 字母 和 单词 了 。 


当然 , 我 们 人 类 是 个 懒惰 的 物种 ， 电 报 操作 员 们 很 快 发 现 ， 他 们 可 以 很 容易 地 通过 
听 钢 笔 弹 起 和 落下 的 声音 来 翻译 电码 。 在 传统 电报 机 中 的 “发 声 器 ”的 帮助 下 ， 钢 笔 最 
终 被 废弃 ， 整 个 装置 看 起 来 如 下 图 所 示 。 
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当 电 报 机 的 电 键 被 按 下 时 ， 发 声 器 中 的 电磁 铁 拉 动 上 面 的 活动 横 杠 下 降 ， 它 会 发 出 “ 滴 ” 
的 声音 。 当 松 开 电 键 的 时 候 ， 横 杠 弹 回 到 原来 的 位 置 ， 发 出 “ 噶 ” 的 声音 。 一 次 快速 的 
“ 滴 - 噶 ” 声 代 表 点 ; 一 次 慢 速 的 “ 滴 一 一 噶 ” 声 则 代表 划 。 


电 键 、 发 声 器 、 电 池 。 还 有 一 些 导 线 连 接 到 一 起 ， 电 报 机 的 电路 示意 图 与 前 面 章节 
中 的 手电 简 电 路 图 很 相似 。 


你 的 电报 站 你 朋友 的 电报 站 


正如 我 们 以 前 所 发 现 的 那样 ， 不 必 非 得 用 两 根 导线 来 连接 两 个 电报 站 。 如 果 地 球 能 
为 我 们 提供 电路 的 男 一 半 的 话 ， 一 根 导线 就 足够 了 。 


就 像 我 们 在 上 一 章 所 做 的 那样 ,我 们 可 以 把 接地 的 电池 用 大 写 “V” 表 示 。 因 此 完整 
的 单 向 系统 如 下 图 所 示 。 


您 的 电报 站 


双向 通信 仅仅 需要 再 增加 一 个 电 键 和 发 报 人 。 这 与 我 们 前 一 章 中 的 做 法 是 类 似 的 。 


电报 机 的 发 明 标志 着 现代 通信 的 开始 。 人 们 第 一 次 能 够 在 视线 或 者 听力 之 外 的 距离 
范围 进行 实时 交流 了 ， 而 且 信息 传递 的 速度 比 骏马 疾驰 还 要 快 。 而 更 加 耐人寻味 的 是 ， 
这 个 发 明 使 用 了 二 进 制 码 。 但 是 在 后 来 的 电子 和 无 线 通信 ( 包括 电话 、 无 线 电 、 电 视 ) 
所 使 用 的 通信 模式 中 ， 二 进 制 码 被 废弃 了 ， 直 到 后 来 它 又 被 应 用 在 了 电脑 、 光 盘 、 数 字 
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影碟 、 数 字 卫 星 电视 广播 和 高 清 电视 上 。 


莫 尔 斯 的 电报 机 在 某 种 程度 上 要 胜 过 其 他 的 设计 ， 因 为 它 对 线路 没有 苛刻 的 要 求 。 
当 你 连 好 电 键 和 发 声 器 之 间 的 线路 后 ， 它 们 一 般 都 可 以 正常 工作 。 而 其 他 的 电报 系统 对 
线路 的 要 求 就 没 这 么 简单 了 。 但 是 正如 我 上 一 章 提 到 的 那样 ， 这 种 电报 机 最 大 的 问题 就 
是 长 导线 所 带 来 的 电阻 。 尽 管 一 些 电报 线路 使 用 高 达 300 伏 的 电压 ， 而 使 有 效 距离 能 
超过 300 英里 ,但 是 线路 还 是 不 能 无 限 延长 。 


显然 ， 设 置 一 个 中 继 系统 是 解决 该 问题 的 一 个 方案 。 每 隔 200 英里 左右 ， 为 一 个 工 
作 人 员 装 配 好 发 声 器 和 电 键 ， 他 就 可 以 接收 信息 ， 然 后 再 把 它 转 发 出 去 。 


现在 ， 想 象 你 已 经 被 电报 公司 聘用 ， 成 为 中 继 系 统 的 一 部 分 。 他 们 把 你 扔 在 纽约 和 
加 利 福 尼 亚 之 间 的 一 个 无 名 之 地 ， 让 你 在 一 个 只 有 一 桌 一 椅 的 小 屋 里 工作 。 一 条 导线 从 
东 面 的 窗户 促进 来 ， 连 接 到 发 声 嚣 上。 而 你 的 电报 机 电 键 连 到 电池 上 ， 最 后 线路 从 西 窗 
伸 出 去 。 你 的 职责 就 是 接收 从 纽约 发 来 的 信息 ,然后 转发 它们 ， 最 终 使 它们 到 达 加 利 福 
尼 亚 。 


开始 时 ， 你 喜欢 接收 完 一 条 完整 的 信息 后 再 把 它 转发 。 首 先 ， 根 据 发 声 器 发 出 的 滴 
答 声 ， 将 字母 记 下 来 ; 当 信息 接收 完毕 时 ， 再 开始 用 你 的 电 键 来 发 送 。 最 后 ， 你 终于 党 
握 了 诀 穿 ， 在 听 到 滴答 声 的 同时 就 可 以 发 送信 息 ， 不 需要 再 把 信息 记录 下 来 了 。 这 节约 
了 不 少时 间 。 


有 一 天 ， 当 你 正在 转发 信息 时 ， 瞄 了 瞄 发 声 器 上 那 根 上 足下 跳 的 横 杠 ， 又 看 了 看 在 
电 键 上 上 下 翻 飞 的 手指 。 然 后 你 就 这 样 来 来 回回 地 蛤 来 晤 去 ， 忆 然 发 现 发 声 器 上 下 跳跃 
的 节奏 与 电 键 是 一 致 的 。 因 此 你 就 去 外 面 找 了 根 小 木 棍 ， 然 后 用 木 棍 和 -- 些 细 绳 把 发 声 
器 和 电 键 连接 到 了 一 起 ， 如 下 图 所 示 。 


现在 ， 设 备 可 以 自己 工作 了 ， 而 下 午 剩余 的 时 间 旷 ， 你 就 可 以 去 休 个 假 ， 钩 个 鱼 。 
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了 


这 真是 个 有 趣 的 想法 ， 但 是 事实 上 ， 艾 纪 尔 ' 莫 尔 斯 在 早 些 时 候 就 已 经 领会 了 这 个 
设备 的 概念 。 刚 刚 我 们 发 明 的 这 个 设备 称 做 “继电器 "。 继 电器 与 发 声 器 很 像 ， 传 进来 的 
电流 驱动 电磁 铁 拉动 金属 本 ， 金 属 村 同时 又 作为 一 个 开关 的 组 成 部 分 ， 而 这 个 开关 连接 
着 电池 和 输出 线路 。 通 过 这 种 方法 ， 输 入 的 比较 弱 的 电流 就 被 “放大 ”成 了 较 强 的 输出 
电流 。 

继电器 的 示意 图 如 下 。 


输入 输出 


当 输入 的 电流 触发 了 电磁 铁 ， 电 磁铁 把 一 个 弹性 金属 条 吸附 下 来 ， 就 像 闲 合 了 开关 
一 样 ， 使 电流 可 以 从 接口 输出 。 


因此 ， 把 一 个 电报 机 电 键 、 一 个 继电器 ， 还 有 一 个 发 声 器 连接 好 ， 差 不 多 就 是 下 图 
的 这 个 样子 。 
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你 的 电报 站 ”中 急 站 ” ”你 朋友 的 电报 站 


继电器 是 一 个 意义 非凡 的 设备 。 当 然 ， 它 是 一 个 开关 ， 但 是 这 个 开关 的 闭合 和 断 开 
并 不 是 由 人 来 操纵 的 ， 而 是 由 电流 控制 的 。 你 可 以 通过 它 来 完成 一 些 不 可 思议 的 事情 。 
实际 上 ， 使 用 它 ， 你 甚至 可 以 装配 好 一 台 近 平 完整 的 计算 机 来 ! 


Wa 


不 错 ， 继 电器 是 一 项 如 此 出 色 的 发 明 ， 以 至 于 电报 博物 馆 也 为 它 留 有 一 席 之 地 。 让 
我 们 悄悄 拿 起 一 台 ， 藏 在 外 套 里 ， 飞 快 地 从 警卫 身边 溜 过 去 。 这 人 台 继电器 用 起 来 将 非常 
方便 。 不 过 我 们 在 使 用 它 之 前 ， 还 要 学 会 如 何 计数 。 
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人 们 很 容易 理解 ， 语 言 只 不 过 是 一 种 编码 。 我 们 之 中 的 许多 人 在 学 校 里 至 少 都 学 过 
一 门 外 语 。 所 以 我 们 知道 , 英文 中 的 “cat”( 猫 ) 在 其 他 语言 中 可 以 写 做 gato、chat、 Katze、 
KOIIIK 或 kdtta。 


然而 ,数字 似乎 并 不 是 那么 容易 随 文化 的 不 同 而 改变 。 不 论 我 们 说 什么 语言 ， 或 对 
数字 使 用 什么 样 的 发 音 ， 在 这 个 星球 上 几乎 所 有 人 都 用 以 下 方式 来 书写 数字 : 


1234 56 7 8 9 10 


这 难道 不 就 是 数学 被 称 做 “通用 语言 ”的 理由 么 ? 


数字 当然 是 我 们 平常 所 能 接触 到 的 一 种 最 抽象 的 编码 。 当 我 们 看 到 数字 : 
3 


不 需要 立刻 将 它 与 任何 事物 联系 起 来 。 我们 可 能 会 联想 到 3 个 苹果 或 者 3 个 别 的 什 
么 东西 。 但 是 当 我 们 从 上 下 文中 得 知 该 数字 表示 的 是 某 个 小 孩 的 生日 、 电 视频 道 、 曲 棍 
球赛 的 得 分 或 蛋糕 食谱 中 面粉 的 杯 数 时 ， 也 能 够 像 认 为 它 代表 3 个 苹果 时 一 样 自然 。 因 
为 数字 最 开始 产生 时 就 很 抽象 ， 所 以 对 于 我 们 来 说 ， 理 解 这 样 一 个 问题 会 有 一 点 困难 。 
这 个 问题 就 是 如 下 数量 的 苹果 : 


”一 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


ee 


A 
: 丢 


1 


并 不 一 定 要 用 符号 “3” 来 表示 。 本 章 及 下 一 章 中 的 很 大 一 部 分 内 容 将 专门 用 来 说 明 如 下 
这 些 苹果 : 


同样 可 以 用 “11” 来 表示 。 


首先 让 我 们 遗忘 数字 10 原 有 的 那些 特性 。 大 多 数 文明 都 是 建立 在 以 10 为 基数 的 数 
字 系 统 上 的 (有 的 时 候 是 以 5 为 基数 )， 这 种 情况 并 不 奇怪 。 最 开始 ， 人 们 用 自己 的 手指 
来 计数 。 如 果 我 们 人 类 有 8 个 或 12 个 手指 ， 那 么 我 们 的 计数 方式 就 会 和 现在 有 所 不 同 。 
英语 中 Digit ( 数字 ) 这 个 词 同 时 也 有 和 手指、 脚趾 的 意思 ， 并 且 还 有 数字 的 意思 ， 这 并 不 
是 巧合 。 而 five (五 ) 和 fist (拳头 ) 这 两 个 单词 的 拥有 相同 的 词根 也 是 同样 的 道理 。 


在 这 个 意义 上 ， 以 10 为 基数 或 使 用 十 进 制 数字 系统 完全 是 随意 的 。 而 且 ， 英 文中 还 
对 基于 十 的 数字 赋予 了 几乎 神奇 的 意义 ， 并 且 给 了 它们 特有 的 名 字 : 十 个 一 年 是 一 个 十 
年 (decade ); 十 个 十 年 是 一 个 世纪 ( century ); 十 个 世纪 就 是 一 个 干 年 (millennium )。 一 
干 个 一 干 就 是 一 个 百 万 (million ); 一 二 个 百 万 就 是 一 个 十 亿 (billion )。 以 下 都 是 10 的 
各 次 宕 。 


10! = 10 

10 = 100 

10 = 1000 ( 千 ) 

10' = 10, 000 

10 = 100, 000 

105= 1,000, 000( 百 万 ) 

10’ = 10, 000, 000 

108 = 100, 000, 000 

10? = 1, 000, 000, 000 (十 亿 ) 
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) 


大 多 数 历史 学 家 认为 数字 最 初 起 源 于 对 事物 的 计数 ， 例 如 : 人 数 、 财 产 或 商业 交易 
的 计数 等 。 举 个 例子 ， 如 果 有 一 个 人 有 四 只 聘 子 ， 用 图 画 表示 为 : 


后 来 ， 专 门 负责 画 鸭 子 的 这 个 人 会 想 :“ 为 什么 我 非得 要 画 四 只 鸭子 ? 为 什么 我 不 画 一 只 
鸭子 再 用 划 线 或 其 他 事物 来 表示 有 四 只 鸭子 呢 ? ” 


然后 直到 有 一 天 ， 出 现 了 一 个 人 ， 他 拥有 27 只 鸭子 ， 这 种 划 线 的 方法 就 显得 很 可 笑 了 。 


fs 


有 人 说 :“ 必 须 想 一 种 更 好 的 方法 。 于 是 一 个 数字 系统 就 诞生 了 。 


Y 


所 有 早期 的 数字 系统 中 ， 只 有 罗马 数字 沿用 到 了 今天 。 我 们 可 以 在 表盘 上 、 纪 念 碑 
和 有 雕像 的 日 期 上 、 一 些 书 的 页 码 中 ， 或 者 在 条 款 的 概述 中 看 到 罗马 数字 ， 而 令 人 最 烦恼 
的 就 是 电影 的 版 权 声明 ( 必须 足够 快 地 破译 位 于 演 职 人 员 表 未 尾 的 “MCMLII” 才 能 知 
道 这 部 影片 是 哪 一 年 发 行 的 )。 


27 只 岗子 用 罗马 数字 表示 为 : 


2 XXVI 


这 个 概念 很 容易 理解 : 和 表示 10 个 划 线 ，V 表示 5 个 划 线 。 


沿用 到 今天 的 罗马 数字 符号 有 : 


IVX LC DM 
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这 里 ,字母 1 表示 1， 可 以 看 做 是 一 个 划 线 或 者 一 根 伟 出 的 手指 。 字 母 V 像 一 只 手 ， 
表示 5。 两 个 V 是 一 个 X， 代 表 数 字 10。 工 是 50。C 来 自 单词 centum， 表 示 100。D 是 
500。 最 后 一 个 ，M 来 自 于 拉丁 文 mille， 意 为 1000。 


尽管 我 们 可 能 不 会 认同 ， 但 在 很 长 一 段 时 间 内 ， 罗 马 数 字 被 人 们 看 做 是 易于 加 减 的 ， 
这 也 是 为 什么 罗马 数字 在 欧洲 作 记 账 之 用 一 直 沿 用 到 今天 。 实 际 上 ， 两 个 罗马 数字 相 加 
的 时 候 只 不 过 是 利用 几 个 规则 将 两 个 数 合 并 ， 这 个 规则 是 : 五 个 1 是 一 个 V, 两 个 V 是 
一 个 X, 五 个 和 是 一 个 工 ， 以 此 类 推 。 


但 是 用 罗马 数字 进行 乘法 和 除法 却 很 复杂 。 很 多 其 他 早期 数字 系统 ( 像 古 希 腊 数 字 
系统 ) 和 有 罗马 数字 系统 相似 ， 它 们 在 用 于 复杂 运算 方面 同样 也 存在 一 定 的 不 足 。 尽 管 古 
希腊 人 发 明 的 非凡 的 几何 学 至 今 仍然 是 高 中 生 的 一 门 课程 ， 但 十 希腊 人 并 不 是 以 代数 而 
著称 的 。 


如 今 我 们 所 用 的 数字 系统 通常 被 称 为 阿拉 伯 数 字 ， 也 可 以 称 为 印度 -阿拉 伯 数 字 系 
统 。 它 起 源 于 印度 ， 被 阿拉 伯 数 学 家 带 入 欧洲 。 其 中 最 著名 的 就 是 波斯 数学 家 穆 罕 默 
德 - 伊 本 穆 萨 - 奥 瑞 兹 穆 (根据 这 个 人 的 名 字 簿 生出 英文 单词 “algoritbm”, 算法 ), 他 在 
公元 825 年 左右 写 了 一 本 关于 代数 学 的 书 ， 其 中 就 用 到 了 印度 的 计数 系统 。 其 拉丁 文 译 
本 可 追溯 到 公元 1120 年 ， 它 对 加 速 整个 欧洲 从 罗马 数字 到 阿拉 伯 数 字 系 统 的 转变 有 着 重 


要 影响 。 


阿拉 伯 数 字 系 统 不 同 于 先前 的 数字 系统 ， 体 现在 以 下 三 点 。 


® 阿拉 伯 数 字 系统 是 和 位 置 相关 的 。 也 就 是 说 ， 一 个 数字 的 位 置 不 同 ， 其 代表 数量 
也 不 同 。 对 于 一 个 数 而 言 ， 其 数字 的 位 置 和 数字 的 大 小 一 样 ， 都 是 很 重要 的 〈 但 
实际 上 ， 数 字 的 位 置 更 重要 )。100 和 1,000,000 这 两 个 数 中 都 只 有 一 个 1， 而 我 们 
知道 ，1,000,000 要 远 远大 于 100。 

。 实际 上 在 早期 的 数字 系统 中 也 有 一 点 是 阿拉 伯 数 字 系统 所 没有 的 ， 那 就 是 用 来 表 
示 数 字 10 的 专门 的 符号 。 而 在 我 们 现在 使 用 的 数字 系统 中 是 没有 代表 10 的 专门 
符号 的 。 

e 另 一 方面 ， 实 际 上 阿拉 伯 数 字 也 有 一 点 是 几乎 所 有 早期 数字 系统 所 没有 的 ， 而 这 
恰恰 是 一 个 比 代 表 数 字 10 的 符号 还 重要 得 多 的 符号 ， 那 就 是 0。 


是 的 , 就 是 0。 小 小 的 一 个 零 无 疑 是 数字 和 数学 史上 最 重要 的 发 明之 一 。 它 支持 位 置 
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计数 法 ,因此 可 以 将 25、205 和 250 区 分 开 来 。0 也 简化 了 与 位 置 无 关 的 数字 系统 中 的 一 
些 非常 复杂 的 运算 ， 尤 其 是 乘法 和 除法 。 

阿拉 伯 数 字 的 整体 结构 可 以 以 我 们 读数 字 的 方式 来 展现 。 以 4825 为 例 , 我 们 读 做 “四 
于 / \ 百 二 十 五 ” ? 意思 就 是 : 


四 干 
八 百 
三 下 
五 


或 者 ， 我 们 也 可 以 将 此 绪 构 以 如 下 写法 写 出 : 
4825=4000+800+20+5 
或 者 ， 对 其 进一步 分 解 ， 可 以 将 数字 写 做 : 
4825=4 x 1000 + 
8 x 100+ 
2x10+ 
Sx1 
或 者 ， 以 10 的 整数 次 寡 的 形式 来 表示 : 
4825 = 4 x 103 十 
8 x 102 十 
2 x 10! 十 
5x10° 
记 住 任何 数 的 0 次 圭 都 等 于 1。 
一 个 多 位 数 中 的 每 一 位 都 有 其 各 自 特 定 的 意义 ， 如 下 图 所 示 。 这 7 个 方 格 能 代表 0~ 
9,999,999 中 的 任何 一 个 数字 。 
每 个 位 置 代 表 10 的 一 个 整数 次 者 。 我 们 不 需要 一 个 专门 的 符号 来 表示 数字 “10”， 
因为 我 们 可 以 将 1 放 在 不 同 的 位 置 ， 并 用 0 作为 占 位 符 。 
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六 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
一 。 


1900000 的 个 壮 


男 一 个 好 处 就 是 ， 以 同样 的 方式 将 数字 置 于 小 数 点 右边 可 以 表示 分 数 。 数 字 
42,705.684 就 是 : 


4x 10, 000 十 
2 x 1000 + 
7x100+ 
0x10+ 

3 x 1 十 
6=10 十 

8 二 100+ 

4 1000 


这 个 数 也 可 以 写 为 不 含 除法 的 形式 ， 如 下 : 


4x 10,000+ 
2 x 1000+ 
7x 100+ 
0x10+ 
5x1+ 
6x0.1+ 

8 x 0.01+ 
4x0.001 


或 用 10 的 寡 的 形式 来 表示 ; 


4x 104 十 
2x 103 + 
7x 10°+ 
0x 101+ 
5x10°+ 
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了 我们 的 十 个 数字 让 


6 x 107+ 
8 x 107+ 
4x103 


注意 ，10 的 寡 指 数 是 如 何 减 小 到 0 再 变 为 负数 的 。 
我 们 知道 ，3 加 4 等 于 7。 类 似 地 ，30 加 40 等 于 70，300 加 400 等 于 700，3000 加 
4000 等 于 7000。 这 就 是 阿拉 伯 数 字 的 “闪光 ”之 处 。 任 何 长 度 的 十 进 制 数 相 加 时 ， 只 要 


根据 一 种 方法 将 问题 分 成 几 步 即 可 ， 而 每 个 步骤 最 多 只 是 将 两 个 一 位 数字 相 加 而 已 。 这 
就 是 为 什么 以 前 有 人 会 强迫 你 记 住 加 法 表 的 原因 。 


3 
3 
4 
5 
6 
7 


7 8 10 11 
8 9 10 11 12 15 
12 13 15 16 
8 8 10 11 12 13 14 15 16 17 
Twolnlalalalsherrie 
从 最 上 边 的 一 行 和 最 左边 的 一 列 分 别 找 出 要 相 加 的 两 个 数字 ， 这 一 行 与 这 一 列 的 交 
又 点 就 是 所 要 得 到 的 和 。 例 如 ，4 加 6 等 于 10。 


同样 ， 当 你 想 将 两 个 十 进 制 数 相 乘 的 时 候 ， 方 法 可 能 稍微 复杂 些 ， 但 是 你 仍然 只 需 
要 将 问题 分 解 成 几 步 ， 做 加 法 和 一 位 数 的 乘法 即 可 。 在 你 的 小 学 时 代 你 一 定 也 被 要 求 必 
须 记 住 下 面 的 乘法 表 。 


7 8 
隔 轴 


位 置 计数 系统 的 好 处 并 不 在 于 它 有 多 么 好 用 ， 而 在 于 对 非 十 进 制 的 系统 而 言 ， 它 仍 
然 是 易于 实现 计数 的 。 我 们 现 有 的 计数 系统 并 不 适用 于 每 种 情况 。 以 10 为 基数 的 数字 系 
统 最 大 的 问题 是 它 对 于 卡通 和 信物 没有 任何 意义 。 大 多 数 卡 通 入 物 每 只 手 (或 爪子 ) 只 有 4 
根 手指 ， 因 此 它们 需要 一 个 以 8 为 基数 的 计数 系统 。 而 有 意思 的 是 ， 许 多 我 们 在 十 进 制 
数 中 所 了 解 到 的 知识 同样 适合 卡通 朋友 们 所 钟爱 的 八进制 计数 系统 。 
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对 于 我 们 人 类 而 言 ，10 是 一 个 非常 重要 的 数字 。10 是 我 人 
趾 的 数目 ， 当 然 我 们 也 希望 所 有 人 的 手指 和 脚趾 都 是 10 个 。 因 
是 我 们 人 类 已 经 适应 了 这 个 以 10 为 基数 的 数字 系统 。 


] 大 多 数 人 拥有 的 手指 或 肢 


为 手指 非常 便于 计数 ， 于 


就 如 前 面 章节 中 所 提 到 的 ,我 们 现在 所 用 的 数字 系统 是 基于 10 的 数字 系统 的 ， 或 称 
为 十 进 制 。 我 们 已 经 非常 习惯 这 个 数字 系统 了 ， 因 此 起 初 也 很 难 再 构想 出 其 他 的 数字 系 


统 。 的 确 ， 当 我 们 看 到 数字 10 的 时 候 ， 我 们 不 自觉 地 就 会 想到 
多 只 鸭子 : 


这 个 数字 代表 了 下 面 这 么 


了 


但 是 ， 数 字 10 之 所 以 指 的 是 这 么 多 只 鸭子 ， 其 唯一 理由 就 在 于 这 些 岗子 的 数目 与 我 
们 的 手指 数目 相同 。 如 果 人 类 的 手指 不 是 10 根 , 我们 数 数 的 方式 就 会 有 所 不 同 ， 那么 10 
就 会 是 男 外 一 个 含义 。 同 样 ， 数 字 10 可 以 代表 这 么 多 内 鸭子 : 


当 我 们 认识 到 ，10 可 以 表示 两 只 鸭子 ,我 们 就 可 以 解释 开关 、 导 线 、 灯 泡 和 继电器 
(进一步 推广 到 计算 机 ) 是 如 何 表示 数字 的 了 。 


如 果 人 类 像 卡通 入 物 那样 每 只 手 有 4 根 手 指 会 怎样 呢 ? 我 们 可 能 就 不 会 想到 建立 一 
个 以 10 为 基数 的 数字 系统 。 相 反 我 们 会 自然 而 然 地 、 不 可 避免 地 想到 建立 一 个 以 8 为 基 
数 的 数字 系统 。 我 们 就 不 会 称 这 个 系统 为 十 进 制 数字 系统 ， 而 称 之 为 八进制 数字 系统 。 


如 果 我 们 的 数字 系统 是 以 8 为 基础 而 建立 的 ， 我 们 就 不 需要 如 下 这 个 符号 : 
9 


将 这 个 符号 给 卡通 人 物 看 的 话 ， 你 会 得 到 这 样 的 反应 :“ 这 是 什么 ? 它 代 表 什么 ? ”如 果 
继续 仔细 考虑 一 下 ， 你 会 发 现 我 们 连 这 样 的 一 个 符号 也 不 会 需要 : 


8 


在 十 进 制 中 ，10 没有 特定 的 符号 ， 因 此 在 八进制 中 ， 同 样 也 没有 表示 8 的 特定 符号 。 


二 


十 进 制 中 我 们 的 计数 方式 是 : 0、1、2、3、4、5、6、7、8、9， 然 后 是 10。 在 八 进 
制 中 数字 系统 中 计数 方式 是 : 0、1、2、3、4、5、6、7， 市 后 是 什么 呢 ? 我们 已 经 将 符 
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号 用 完了 。 在 这 里 唯一 有 意义 的 只 有 10, 而 在 这 里 的 正确 答案 恰恰 就 是 10。 在 八进制 中 ， 
7 之 后 的 下 一 个 数字 是 10。 但 是 这 个 “10” 代 表 的 并 不 是 人 类 手指 的 数量 。 在 八进制 中 ， 
“10” 代 表 的 是 卡通 入 物 手指 的 数量 。 


使 用 非 十 进 制 的 数字 系统 时 ,你 可 以 将 “10” 读 作 “ 一 零 ”, 这 样 可 以 避免 一 些 混 淆 。 
类 似 地 ,，“13” 读 作 “ 一 三 ”,“20” 读 作 “ 二 零 ”"。 要 想 真正 避免 混淆 ， 可 以 将 “20” 读 
作 “ 基 于 8 的 数 二 零 ” 或 “八进制 二 零 ”。 
尽管 已 经 用 完了 所 有 的 手指 和 脚趾 ， 但 我 们 仍 能 够 用 八进制 继续 数 下 去 。 这 与 十 进 
制 基本 相同 ,但 是 我 们 跳 过 了 数字 8 和 9。 当 然 ， 相 同 数字 所 代表 的 数量 是 不 同 的 ; 


0，1，2,，3，4，53，6，7，10，11，12，13，14，13，16，17，20，21，22，23 ，24 ， 
25, 26, 27, 30, 31, 32, 33, 34, 35, 36, 37, 40, 41, 42, 43, 44, 45, 46, 47, 
50, 51, 52, 53, 54, 55, 56, 57, 60, 61, 62, 63, 64, 65, 66, 67, 70, 71, 72, 
73, 74, 753, 76, 77, 100.…… 


这 里 最 后 一 个 数字 我 们 读 做 “一 零 零 "。 这 是 卡通 人 物 手 指 的 数量 自身 相 乘 所 得 的 结果 。 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
lL 


当 书 写 十 进 制 和 八进制 数 时 ， 我 们 可 以 利用 下 标 标注 来 区 别 不 同 数字 系统 ， 避 免 混 
淆 。 下 标 TEN 表示 十 进 制 ，EIGHT 表示 八进制 。 


这 样 ， 白 雪 公 主 遇 到 的 小 矮人 数量 是 7reN 或 7gl6ur; 
卡通 人 物 的 手指 数 是 8raN 或 10aoar; 

贝多 分 所 写 的 交响 曲 的 数目 是 9raN 或 1laotr; 

人 类 手指 的 数量 是 10reN 或 12aeari 

一 年 中 的 月 份 数 是 12ra8 或 14arzoari 

两 个 星期 的 天 数 是 14reN 或 16greur; 


“情人 ”的 生日 庆祝 会 是 16raN 或 20gt6Hr; 


一 天 中 的 小 时 数 是 24reN 或 30EropT; 


拉丁 字母 表 中 的 字母 数 是 26rew 或 32toar; 

一 夸 陪 的 液体 相当 于 的 盘 司 数 是 32reN 或 40pcar; 
一 副 纸 牌 的 张 数 是 52raN 或 64giorr; 
棋盘 的 格 数 是 64rmN 或 100arear; 

日 落 大 道上 最 有 名 的 地 址 是 77raN 或 11Seicar; 


美式 足球 场地 的 面积 是 100rmN 或 144moar; 
温 网 首届 女子 单打 的 初赛 人 数 是 128rew 或 200picari; 


孟菲斯 市 的 面积 是 236reN 或 400 grour。 
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注意 , 在 上 面 一 系列 的 八进制 数 中 出 现 了 几 个 好 整数 ( nice round number ), 如 100 monr、 
200 acar 和 400 sar。 根 据 规 定 ， 在 十 进 制 中 ， 好 整数 通常 是 指 结尾 有 若干 个 零 的 数 。 在 
结尾 有 两 个 零 的 十 进 制 数 代表 的 是 100rsw, 而 100rax 表示 10rm 乘 以 10rewo 在 八进制 数 中 ， 
结尾 有 了 两 个 零 代表 是 100aear， 而 100 mcar 表 示 10som 乘 以 10Bomr (或 8rm 乘 以 8 即 
64 TEN )。 


8 十 的 蔡 代 品 下 一 
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你 可 能 还 会 注意 到 ,这 些 好 整数 100 aoar、.200amemr 和 400aoar 在 十 进 制 中 分 别 与 64reN、 
128 Tew 和 256 ra 相等， 它们 全 是 2 的 整数 次 究 。 这 是 非常 有 意义 的 。 例 如 ，400 air 
等 于 4 sipr 乘 以 10 aar 乘 以 10 gonr， 而 这 里 所 有 的 数 都 是 2 的 整数 次 需 。 任 何 2 的 整 
数 次 寡 乘 以 2 的 整数 次 宪 的 结果 依然 是 2 的 整数 次 寡 。 


下 表 给 出 了 一 些 2 的 整数 次 等 的 十 进 制 及 其 对 应 的 八进制 的 表示 形式 。 


最 右 列 的 好 整数 暗示 我 们 ， 十 进 制 以 外 的 数字 系统 可 能 对 使 用 二 进 制 码 有 所 帮助 。 


在 结构 上 ， 八 进 制 数字 系统 与 十 进 制 数字 系统 并 没有 什么 不 同 。 它 们 只 是 在 细节 上 
存在 一 些 差异 。 例 如 ， 八 进 制 数 中 的 每 个 位 所 代表 的 值 是 该 位 数字 乘 以 8 的 整数 次 祖 的 


结果 。 
下 
8 的 个 数 


64 的 个 数 
512 的 个 数 
4096 的 个 数 
32768 的 个 数 


这 样 > 一 个 八进制 数 3725 EIGHT 可 以 分 解 成 如 下 形式 : 


3725 pteur =3000 aaoar +700 prGnr +20 may +5 BIGHT 
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同样 还 可 以 写成 若干 种 不 同 的 形式 ， 下 面 是 利用 十 进 制 的 8 的 整数 次 吞 写 出 的 一 种 形式 : 


3725 EIGHT 一 3 x512 TEN 十 
7 x 64TEN 十 
2 x BTENT+ 


Sxl 
采用 八进制 形式 的 8 的 整数 次 器 ， 表 现形 式 如 下 : 


3725 piopr = 3 x 1000 grGrr 十 
7 x 100 prour + 
2 x 10Er6nr + 
Sx1 


还 有 一 种 拆 分 形式 : 
3725 grogr = 3 x 83 二 
7 x 82+ 
2 x 8!+ 
5x8° 
如 果 用 十 进 制 数 计算 出 结果 , 会 得 到 2005 rse。 这 就 是 将 八进制 数 转化 为 十 进 制 数 的 方法 。 
我 们 可 以 像 进行 十 进 制 数 的 加 法 和 乘法 那样 ， 对 八进制 数 进行 加 法 或 乘法 运算 。 不 
同 的 是 ,我们 要 采用 不 同 的 表 来 对 各 个 数位 进行 乘法 或 加 法 运算 。 下 面 是 八进制 数 的 加 
法 表 。 


例如 ，5 maar +7 iGnr =14aaar。 我 们 还 可 以 将 两 个 更 长 的 / \ 进 制 数 按照 与 十 进 制 相同 
的 方法 相 加 : 


135 
+ 643 
1000 


首先 要 从 最 右 的 一 列 开始 ，5 加 3 等 于 10， 结果 为 0， 进 位 1; 1 加 3 加 4 等 于 10， 
结果 为 0， 进 位 1; 1 加 1 加 6 等 于 10。 


同样 , 在 八进制 中 , 2 乘 以 2 结果 依然 为 4。 但 是 3 乘 以 3 却 不 等 于 9。 那 是 多 少 呢 ? 
在 这 里 ，3 乘 以 3 结果 是 11 aroar， 其 与 9rek 所 代表 的 数量 相等 。 下 面 为 八进制 乘法 的 乘 


在 这 里 , 4 x 6 等 于 30moar, 而 30acar 与 24rm 等 价 ,， 也 就 是 与 十 进 制 中 的 4 x 6 相等 。 


八进制 数字 系统 与 十 进 制 数字 系统 一 样 ， 都 是 有 效 的 。 但 是 让 我 们 更 进一步 来 看 ， 
既然 已 经 为 卡通 人 物 开 发 了 一 套数 字 系 统 ， 就 让 我 们 再 制订 一 套 适合 龙虾 的 数字 系统 吧 。 
实际 上 龙虾 根 本 没有 手指 , 但 是 在 它们 前 爪 的 末端 都 有 鳌 。 适 用 于 龙虾 的 数字 系统 是 以 4 
为 基数 的 四 进 制 (quaternary ) 数字 系统 。 
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四 进 制 数 字 系 统 是 像 这 样 计 数 的 : 0，1，2，3，10，11，12，13，20，21，22，23， 
30，31，32，33，100，101，102，103，110， 等 等 。 


这 里 我 不 打算 在 四 进 制 数 上 花 太 多 的 时 间 ， 因 为 接 下 来 我 们 即将 转 入 一 个 更 为 重要 
的 话题 。 通 过 下 图 我 们 可 以 看 出 四 进 制 中 每 一 位 是 如 何 跟 4 的 某 个 整数 次 只 相对 应 的 。 


下 1 的 个 数 
4 准 个 数 


16 的 个 数 
64 的 个 数 
256 的 个 数 
1024 的 个 数 


四 进 制 数 31232 可 以 写 做 如 下 形式 : 


31232Four = 3 x 296TEN 十 
1 x 64rEN+ 
2 x 16ren+ 
3 xd4ren+ 


2x1 
等 价 于 : 


31232Four = 3 x 10000 Four + 
1 x 1000 Four + 
2 x 100 pour 十 
3 x 10FouR 十 


2x1 
同样 可 以 写成 : 
31232rouR =3 x 44+ 
1 x 43 十 
2 x 42 十 
3 x 4! 十 
2x4 
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8 十 的 蔡 代 品 下 


果 以 十 进 制 数 的 形式 计算 其 结果 ， 我 们 会 发 现 31232 rour 等 价 于 878 raw。 


现在 , 我 们 要 和 做 一 个 跳跃 并 且 是 最 远 的 一 跳 。 如 果 我 们 是 海豚 ， 那 么 就 必须 用 两 个 
鳍 来 计数 。 这 个 数字 系统 称 为 以 2 为 基数 的 数字 系统 ， 或 二 进 制 。 这 样 的 话 我 们 似乎 只 
有 两 个 数字 了 ， 这 两 个 数 分 别 为 0 和 1。 


为 


us 


A 


0 和 1 现在 已 不 是 我 们 要 处 理 的 全 部 问题 了 , 而 我 们 还 需要 练习 一 下 才能 习惯 使 用 二 
进 制 数 。 二 进 制 数 最 大 的 问题 是 数字 用 完 得 很 快 。 例 如 ， 下 图 就 是 海豚 如 何 用 它 的 鱼 来 
计数 的 例子 。 


是 的 ， 在 二 进 制 中 ，1 的 下 一 个 数字 是 10。 这 让 人 惊讶 ， 但 也 并 不 是 什么 意外 。 无 
论 使 用 哪 种 计数 系统 ， 当 单个 的 数字 用 完 时 ， 第 一 个 两 位 数 就 是 10。 二 进 制 系统 这 样 计 
数 的 : 


0, 1, 10, 11, 100, 101, 110, 111, 1000, 1001, 1010, 1011, 1100, 1101, 1110, 
1111，10000，10001.…… 


这 些 数 看 起 来 似乎 很 大 ， 但 实际 上 并 不 是 这 样 的 。 准 确 地 说 ， 二 进 制 数 的 长 度 增 长 
得 很 快 而 非 数 值 增 大 得 快 : 


人 类 的 头 的 个 数 是 ln 或 1 rwo; 
海豚 身上 鳍 的 个 数 是 27pw 或 10 Two; 


一 个 大 汤匙 中 的 小 茶匙 的 数目 为 3ren 或 11 rwo; 


正方 形 的 边 数 是 4 TEN 或 100 7wo; 


人 类 一 只 手 的 手指 数 是 Sr 或 101 rwo; 


昆虫 的 腿 数 是 6rgkg 和 110 ywo; 
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一 周 中 的 天 数 是 7rm 或 111 rwoi 

八重 奏 中 演奏 者 的 人 数 是 8ten 或 1000 Two; 

银河 系 中 行星 ( 包括 冥王 星 ) 的 总 数 是 9reN 或 1001 two; 

牛仔 帆 的 重量 以 加 仑 计算 为 10Tew 或 1010ywo。 

在 一 个 多 位 二 进 制 数 中 ， 数 字 的 位 置 和 2 的 整数 次 戎 的 对 应 关系 为 


| 中 , 
2 的 个 数 

4 的 个 数 

8 的 个 数 

16 的 个 数 


32 的 个 数 
因此 ,任何 一 个 以 1 开头 而 后 面 全 是 0 的 二 进 制 数 一 定 都 是 2 的 整数 次 震 。 罕 指数 
就 等 于 这 个 二 进 制 数 中 0 的 个 数 。 
以 下 是 2 的 各 整数 次 寡 的 扩展 表 ， 它 可 以 用 来 说 明 这 条 规则 。 
- 2 十 进 制 数 | 八进制 数 | 四 进 制 数 
2° 
21 


1000000 
10000000 
100000000 
1000000000 


2000 100000 10000000000 
4000 200000 100000000000 
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了 
和 


101101011010rwo= 1 x 2048TgN + 
0 x 1024 ren + 
1 x S12TEN 十 
1 x 246TEN 十 


0 x 1287EN+ 


1 x 64TEN 十 
0 x 32 TEN 十 
lx l6ren+ 
1 x 8TEN 十 
0 x 4Tr6N 十 
1 x 2TgN 十 


0 x 17EN 


同样 也 可 以 用 下 面 这 种 方式 表示 : 


如 果 将 各 个 部 分 以 十 进 
2,906 TENo 


二 
1 


101101011010rwo= 1 x 21 二 
0 x 220 十 
1 x 29 十 
1 x 28 十 
0x2’+ 
1 x 25+ 
0x25 十 
1 x24+ 
1 x 2 十 


0 x 22 十 
1 x 21 二 


0x2° 


因数 的 形式 相 加 ， 会 得 到 2048 + 512 + 256 + 64+16+8+2， 即 


为 了 更 简明 、 更 便捷 地 将 二 进 制 数 转换 为 十 进 制 数 ， 你 可 能 会 更 喜欢 借助 我 准备 的 


下 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


模板 来 进行 转换 : 


DODDODDDDU 


x128 x64 x*x32 xi6 x8 X4 X2 关上 
DEFOD 0 
这 个 模板 可 以 将 一 个 数 转换 最 大 长 度 为 8 的 二 进 制 数 ， 但 是 它 很 容易 扩展 。 在 使 用 
模板 的 时 候 ， 将 8 位 二 进 制 数 填 入 到 上 面 一 行 的 格子 里 ， 每 个 格子 一 位 。 做 8 个 乘法 运 
算 ， 然 结果 注入 到 下 而 一行 的 8 个 小 格子 里。 再 将 这 8 个 格子 中 的 数 相 加 训 全 得 
终结 果 。 下 面 就 举例 说 明 如 何 得 到 与 二 进 制 数 10010110 相等 的 十 进 制 数 。 
回回 口 加 加 


x128  x64  x32 xl6 x8 X4 X2 x1 


国 : 回 : 回 : 因 : 回 : 团 : 回 ,加 -Ga 
将 十 进 制 数 转换 成 二 进 制 数 就 没 那么 直接 了 。 下 面 是 一 个 能 够 帮 你 将 0~ 255 范围 内 
的 十 进 制 数 转换 为 二 进 制 数 的 模板 。 


DOODDODDUDDOD 


加 加 生生 各 


这 个 转换 实际 上 比 看 上 去 要 麻烦 得 多 ， 因 此 一 定 要 仔细 地 按照 下 面 的 指导 来 操作 。 
将 整个 十 进 制 数 (小 于 或 等 于 255 ) 填 入 到 上 面 一 行 最 左 端的 格子 中 。 用 第 一 个 除数 ( 128 ) 
去 除 这 个 数 。 所 得 的 商 吐 入 正 下 方 的 格子 左下 角 的 格子 )， 余 数 填 入 右边 的 格子 《上 面 
一 行 左 数 第 二 个 格子 )。 用 第 一 个 余数 再 除 以 下 一 个 除数 64。 依照 模板 的 顺序 用 同样 的 方 
法 继续 进行 下 去 。 


要 记 住 ， 每 次 求 得 的 商 只 能 是 0 或 者 1。 如 果 被 除数 小 于 除数 ， 商 为 0， 余 数 就 是 被 
除数 。 如 果 被 除数 大 于 或 等 于 除数 ， 那 么 商 为 1， 余数 就 是 被 除数 减 去 除数 所 得 之 差 。 下 
面 以 150 为 例 进行 转换 。 


8 264 2 +i6 =4 
| 器 口 [5 


如 果 需 要 对 两 个 二 进 制 数 进行 加 法 或 乘法 ， 直 接 运算 可 能 会 比 转换 成 十 进 制 再 进行 
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你 记 住 了 如 下 表格 ， 


运算 要 简单 些 。 这 将 是 你 真正 喜欢 二 进 制 数 的 地 方 。 想 象 一 下， 如 
掌握 加 法 将 是 一 件 多 么 迅速 的 事情 啊 。 


让 我 们 用 这 个 表格 来 计算 两 个 二 进 制 数 的 和 : 
1100101 


十 昌 41044 人 0 
1001 11041 


从 最 右 一 列 开始 : 1 加 0 等 于 1。 右边 第 二 列 : 0 加 1 等 于 1。 第 三 列 : 1 加 1 等 于 0， 
进 1。 第 四 列 : 1 (进位 ) 加 0 加 0 等 于 1。 第 五 列 : 0 加 1 等 于 1。 第 六 列 : 1 加 1 等 于 
0， 进 1。 第 七 列 : 1 (进位 ) 加 1 加 0 等 于 10。 

乘法 表 甚 至 比 加 法 表 还 要 简单 ， 因 为 该 表 可 以 由 两 个 基本 的 乘法 规则 推导 出 来 : 任 
何 数 乘 以 0 结果 都 为 0， 任何 数 乘 以 1， 结 果 都 是 这 个 数 本 身 。 


以 下 是 13 Ten 与 1LraN 的 二 进 制 乘法 运算 过 程 ， 

4401 

XX 和 往生 
4491 

1101 
0908 
4401 
100011344 


结果 为 143 rExo 

人 们 在 使 用 二 进 制 数 的 时 候 通常 将 它们 写成 带 有 前 导 零 的 形式 〈 即 第 一 个 1 的 左边 
有 和 零 )。 例如 0011, 而 不 是 写 做 11。 这 样 写 不 会 改变 数字 的 大 小 , 仅仅 是 为 了 美观 。 例如， 
以 下 是 前 16 个 二 进 制 数 以 及 与 它们 等 价 的 十 进 制 数 。 
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人 
十 进 制 数 


0000 


0010 


0101 
0110 


O11ll 


| 
1 
0011 3 


1000 


0 
lo | 


1101 
1110 


1111 


让 我 们 再 看 一 下 这 一 列 二 进 制 数 。 仔 细 考 虑 这 4 个 和 


们 在 一 列 中 自 上 而 下 是 以 怎样 的 规律 交替 的 。 


| 
一 | 
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gs 最 右边 的 一 列 一 直 在 0 和 1 之 间 交 替 。 


s 右 数 第 二 列 是 在 每 两 个 0 和 两 个 1 之 间 相 互 交 替 。 
s 下 一 列 是 在 每 四 个 0 和 每 四 个 1 之 间 相 互 交替 。 


1011 
1100 


s 再 下 一 列 是 在 每 八 个 0 和 每 八 个 1 之 间 相 互 交替 。 


直列 中 每 一 列 的 1 和 0, 注意 它 


这 是 很 有 条 理 的 ， 难 道 不 是 么 ?事实 上 ， 只 要 再 重复 这 16 个 数字 并 且 在 每 个 数字 的 


前 面 加 一 个 1 就 可 以 很 容易 地 写 出 后 面 的 16 个 数字 。 


十 进 制 数 
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8 十 的 革 代 品 - 


从 另外 一 种 角度 来 看 : 当 以 二 进 制 计数 的 时 候 ， 最 右边 的 一 位 〈 最 低位 ) 以 0 和 1 
交替 。 每 当 该 位 由 1 变 为 0， 从 右边 数 的 第 一 位 (次 低位 ) 也 随 之 改变 -一 不 是 由 0 变 到 
1， 就 是 由 1 变 到 0。 因 此 ， 每 次 只 要 有 一 个 二 进 制 数 位 的 值 由 1 变 到 0， 紧 挨 着 的 高 位 
数字 也 会 发 生变 化 ， 而 且 其 变化 不 是 由 0 到 1 就 是 由 1 到 0。 

在 书写 一 个 比较 大 的 十 进 制 数 的 时 候 ， 通 常 在 每 三 位 数字 之 间 用 一 个 逗号 隔 开 ， 这 

会 让 人 很 清楚 地 读 出 数字 的 大 小 。 例 如 ， 当 你 看 到 数字 12000000 时 ， 你 可 能 不 得 不 去 
数 一 下 其 中 0 的 个 数 才 知道 这 个 数 是 多 少 , 但是， 如 果 数 字 写 做 12,000,.000， 你 一 眼 就 会 
知道 它 是 一 干 二 百 万 。 

二 进 制 数 的 位 长 度 增 加 得 特别 快 。 例 如 ， 一 干 二 百 万 在 二 进 制 中 应 表示 为 : 
101101110001101100000000。 为 了 让 二 进 制 数 更 易 读 , 通常 在 每 四 个 数字 之 闻 用 一 个 连 字 
符 来 分 开 ， 例 如 ，1011-0111-0001-1011-0000-0000， 或 者 每 四 位 空 出 一 个 空格 : 1011 0111 
0001 1011 0000 0000。 本 书 的 后 面 ， 我 们 将 看 到 更 简单 的 二 进 制 数 的 表示 方法 。 


通过 将 数字 系统 减少 至 只 有 0 和 1 两 个 数字 的 二 进 制 数字 系统 ， 我 们 已 经 讨论 得 足 
够 深入 。 不 可 能 再 找到 比 二 进 制 数字 系统 更 简单 的 数字 系统 了 。 此 外 ， 二 进 制 数字 系统 
还 在 算术 与 电子 技术 之 间架 起 了 一 座 桥梁 。 在 之 前 的 章节 中 , 我 们 所 看 到 的 开关 、 电 线 、 
灯泡 ， 还 有 继电器 等 物体 ， 都 可 以 用 来 表示 二 进 制 数 0 和 1。 


电线 可 以 表示 二 进 制 数字 。 如 果 有 电流 流 过 这 根 电线 就 代表 二 进 制 数字 1, 如 果 没 有 ， 
则 代表 二 进 制 数字 0。 


69 4 


一 下 可 一 下 在 计 外 关于 有 的 言 
| 


开关 可 以 表示 二 进 制 数字 。 如 果 开 关 接 通 ( 或 闭合 ) 就 代表 二 进 制 数 字 1， 如 果 开 关 
关 断 〈 或 断 开 )， 则 代表 二 进 制 数 字 0。 

灯泡 可 以 表示 二 进 制 数字 。 如 果 灯 泡 点 亮 ， 就 代表 二 进 制 数字 1， 如 果 没 点 亮 ， 则 代 
表 二 进 制 数字 0。 

电报 继电器 可 以 表示 二 进 制 数字 。 如 果 继 电器 闭合 , 就 代表 二 进 制 数字 1, 如 果断 开 ， 
则 代表 二 进 制 数字 0。 

二 进 制 数 与 计算 机 之 间 有 着 紧密 的 联系 。 

大 约 在 1948 年 ， 美 国 数学 家 约翰 威 尔 德 . 特 克 (John Wilder Turkey， 生 于 1915 
年 ) 就 意识 到 随 着 计算 机 的 普及 ， 二 进 制 数 很 可 能 会 在 未 来 发 挥 更 重要 的 作用 。 他 决定 
创造 一 个 新 的 、 更 短 的 词语 来 代替 使 用 起 来 很 不 方便 的 五 音节 词 -一 -binary digit。 他 曾经 
考虑 使 用 bigit 和 binit， 但 是 最 终 他 还 是 选用 了 这 个 短小 、 简 单 、 精 巧 而 且 非 常 可 爱 的 
词 一 一 bit。 
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托尼 奥兰多 :在 他 1973 年 所 写 的 一 首 歌 中 这 样 请 求 他 垫 爱 的 人 :“ 请 在 橡树 上 系 上 
一 条 黄 丝 带 ”。 他 没有 要 求爱 人 进行 详细 的 解释 或 者 进行 过 多 的 讨论 。 他 不 想 听 到 任何 的 
“如 果 ”“ 而 且 ” 和 “但 是 ”。 尽 管 这 首 歌 是 根据 那些 可 能 在 真实 生活 中 发 生 过 的 复杂 感 
情 和 动人 的 往事 所 号 的 , 但 这 个 男人 真正 想 要 的 答案 仅仅 是 一 个 简单 的 “是 ”或 “不 是 "。 
他 希望 在 树 上 系 一 条 黄 丝带 来 表示 “是 的 ， 尽 管 你 做 了 很 多 错 事 ， 并 且 入 狱 三 年 ， 但 我 
依然 希望 你 可 以 回来 和 我 共同 生活 。” 他 希望 用 树 上 没有 系 黄 丝 带 来 表示 : “你 连 停 在 这 
里 都 别 想 。 


这 是 两 个 界线 分 明 、 相 互 排斥 的 答案 。 托 尼 “' 奥兰多 并 没有 唱 “ 如 果 你 想 考虑 一 下 ， 


1 托尼 奥兰多 (Tony Orlando ) ， 美 国歌 手 ，1944 年 出 生 于 纽约 ， 是 一 位 希腊 和 波多 黎 各 
的 混血 儿 ，《 老 橡树 上 的 黄 丝 带 》 是 他 的 经 典 名 曲 ， 脸 实 人 口 。 歌 曲 描述 一 个 在 监狱 服刑 
的 丈夫 在 即将 服刑 期 满 的 前 夕 ， 因 担心 远 在 家 乡 的 妻子 不 接受 他 ， 写 信 告诉 妻子 ， 如 有 果 愿 
意 再 次 接纳 他 ， 请 在 他 出 狱 返 家 的 当天 ， 在 家 门口 的 老 橡 树 上 系 上 一 条 黄 丝带 ;如 果 他 没 
有 看 到 黄 丝 带 的 话 ， 他 就 会 识 相 地 默默 离开 。 结 果 这 位 丈夫 出 狱 返 家 时 ， 家 门口 的 老 橡 树 
上 绑 满 了 数 以 百 计 的 黄 丝带 在 空中 飞扬 ， 令 他 十 分 感动 。 后 来 ， 绑 黄 丝 带 成 为 全 美国 的 一 
种 风俗 ， 表 示 迎 接 久别 的 亲人 回 家 。 一 一 译 者 注 


一 下 编码 一- 隐匿 在 计算 机 软 硬 件 背后 的 语言 
i- 0 


就 系 半 条 黄 丝 带 吧 ”或 者 “如 果 你 不 再 爱 我 , 但 我 们 依然 是 好 朋友 ,就 请 系 上 蓝 丝 带 吧 。” 
相反 ， 他 将 问题 简化 得 非常 非常 简单 。 


3 


还 有 几 个 和 系 黄 丝 带 具有 同样 效果 的 例子 (但 可 能 无 法 用 在 诗 里 ): 选择 一 种 交通 标 
志 放 在 院子 外 面 ， 来 表示 “请 进 ” 或 “此 路 不 通 ”。 


或 者 在 门 上 挂 一 个 牌子 上 面 写 着 “关门 ”或 “营业 ”。 
或 者 用 窗 了 里 的 将 灯 的 亮 灭 来 表示 : “关闭 ” 或 “打开 ”。 


如 果 这 就 是 你 想 说 的 ， 你 :可 以 选择 很 多 方法 来 表示 “是 ”或 者 “不 是 ”。 你 不 需要 用 
一 句 话 、 一 个 单词 甚至 一 个 字母 来 表达 。 你 所 需要 的 只 是 一 个 比特 ， 也 就 是 只 需要 一 个 0 
或 1 即 可 。 


就 如 前 面 章 节 所 提 到 的 ， 十 进 制 与 其 他 数字 系统 相 比 并 没有 什么 不 同 ， 只 是 我 们 通 
常 使 用 它 来 计数 。 很 明显 ， 我 们 使 用 十 进 制 数字 系统 是 因为 我 们 有 十 个 手指 。 如 果 我 们 
将 数字 系统 建成 八进制 数字 系统 如 果 我 们 是 卡通 人 物 ) 或 四 进 制 数字 系统 (如果 我 们 
是 龙虾 )， 甚 至 二 进 制 数字 系统 (如 果 我 们 是 海豚 )， 也 是 合乎 情理 的 。 


但 是 二 进 制 数字 系统 存在 一 点 特殊 性 。 这 个 特殊 性 就 在 于 它 是 人们 所 能 得 到 的 最 简 
单 的 数字 系统 。 二 进 制 数字 系统 中 只 有 两 个 数字 一 0 和 1。 如 果 想 进一步 简化 这 个 数字 
系统 ， 就 只 好 把 1 去 抒 ， 最 后 我 们 就 锌 下 的 就 只 有 一 个 数字 0 了 。 但 仅 用 一 个 0 是 做 不 
了 任何 事情 的 。 


单词 “bit( 比特》 被 创造 出 来 代表 英文 “binary digit" ， 它 的 确 是 和 计算 机 有 关 的 词 
语 中 最 可 爱 的 一 个 。 当 然 , 这 个 词 也 有 它 一 般 的 意义 :“ 一 小 部 分 , 程度 很 低 或 数量 很 少 ”。 
这 个 意义 很 贴切 ， 因 为 1 比特 一 一 个 二 进 制 数字 位 一 一 确实 是 一 个 非常 小 的 量 。 


通常 当 一 个 新 的 词语 出 现 的 时 候 ， 它 都 会 有 自己 新 的 意义 。 比 特 这 个 词 也 是 这 样 的 。 
1 比特 的 意思 并 不 仅仅 是 海豚 用 来 计数 的 二 进 制 数字 位 所 包含 的 意义 。 在 计算 机 时 代 ,， 比 
特 被 看 做 是 组 成 信息 块 的 基本 单位 。 
这 是 一 个 大 胆 的 声明 。 当 然 ， 二 进 制 数 不 是 传达 信息 的 唯一 方法 。 字 母 、 单 词 、 莫 
尔 斯 码 、 布 莱 叶 言 文 和 十 进 制 数 都 可 以 来 表达 信息 。 关 键 在 于 ， 比 特 所 传递 的 信息 量 极 
少 。1 比特 是 可 能 存在 的 最 小 的 信息 量 。 任 何 小 于 1 比特 的 内 容 都 根本 算 不 上 是 信息 。 
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于 1 比特 表示 的 是 可 能 存在 的 最 小 信息 量 ， 那 么 复杂 一 些 的 信息 就 可 以 用 多 位 二 进 制 数 
来 表达 (我 们 说 比特 传递 的 信息 量 “ 小 ”， 并 不 是 说 它 传送 的 信息 不 重要 。 事 实 上 黄 丝 带 
对 于 与 它 相 关 的 两 个 人 来 说 是 一 个 非常 重要 的 信息 )。 


“ 听 ， 我 的 孩子 ， 你 们 很 快 就 能 听 到 保罗 ' 里 威 尔 (Paul Revere ) 午夜 的 马蹄 声 。” 享 
利 . 沃 兹 沃 思 : 朗 福 罗 ( Henry Wadsworth Longfellow ) 写 到 。 尽 管 他 在 描述 保罗 . 里 威 尔 
是 如 何 通知 美国 人 英国 殖民 者 入 侵 的 消息 时 不 一 定 与 史实 完全 一 致 ， 然 而 他 确实 提供 了 
一 个 耐人寻味 的 利用 二 进 制 传递 重要 信息 的 例子 : 


他 对 他 的 朋友 说 :“ 今 晚 如 果 从 镇 里 来 的 英国 军队 通过 海路 或 陆路 入 侵 , 你 
就 在 北 教堂 钟楼 的 拱门 处 高 高 挂 起 提 灯 作为 特殊 信号 -一 蓝 提 灯 表 示 从 英 军 
从 陆路 进军 ， 两 益 则 表示 英 军 从 海路 入 侵 ……” 


总 结 起 来 就 是 说 ,保罗 ，。 里 威 尔 的 朋友 有 两 昼 提 灯 。 如 果 英 国 军队 从 陆路 进犯 ， 他 会 
在 教堂 钟楼 上 挂 起 一 孝 提 灯 。 如 果 英 国 从 海路 进军 ， 他 会 将 两 伪 提 灼 都 在 教堂 钟楼 上 挂 起 。 


然而 ， 朗 福 罗 并 没有 明确 地 提 到 所 有 的 可 能 性 。 他 留 下 了 第 三 种 可 能 的 情况 没有 说 ， 
那 就 是 英 军 根本 没有 入 侵 。 朗 福 罗 已 经 上 暗示， 如果 是 这 样 的 话 可 以 通过 不 在 教堂 钟楼 上 
挂 提 灯 来 表示 。 


假设 两 画 提 和 灯 实 际 上 是 永久 固定 在 教堂 钟楼 上 的 。 通 党 它们 不 会 被 点 亮 。 


这 代表 英 军 还 没有 入 侵 。 如 果 一 荔 提 灯亮 起 : 


T 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
ep id 


表示 英 军 从 陆路 入 侵 。 如 果 两 画 灯 都 被 点 亮 : 


表示 英 军 正 由 海路 入 侵 。 

每 一 徐 提 灯 都 代表 一 个 比特 。 点 亮 的 提 灯 表示 比特 值 为 1; 未 点 亮 的 提 灯 表示 比特 值 
为 0。 托尼 :奥兰多 已 经 向 我 们 证 明了 传送 只 有 两 种 可 能 性 的 信息 只 需要 一 个 比特 。 如 果 
保罗 ，. 里 威 尔 只 需要 被 告知 英 军 将 要 入 侵 〈 而 不 管 他 们 将 从 何 处 入 侵 )， 一 将 提 灯 就 足够 
了 。 这 苗 提 灯亮 起 表示 入 侵 ,不 亮 则 表示 今夜 无 事 。 


要 表达 包含 三 种 可 能 性 的 消息 ， 则 还 需要 再 加 一 荔 提 灯 。 如 果 有 了 第 二 荔 提 灯 ， 这 
两 伪 提 灯 在 一 起 可 以 表达 四 种 可 能 的 信息 : 


00= 英 军 今 晚 不 会 入 侵 
01 = 英 军 正 由 陆路 入 侵 
10= 英 军 正 由 陆路 入 侵 
11 = 英 军 正 由 海路 入 侵 
保罗 里 威 尔 将 三 种 可 能 性 用 两 音 提 灯 来 传送 的 做 法 事实 上 是 相当 老道 的 。 用 通信 
理论 的 术语 来 说 ， 他 运用 了 “ 宛 余 ”(redundancy ) 来 抵消 噪声 的 影响 。 通 信 理 论 中 ， 噪 
声 (noise ) 是 指 影响 通信 效果 的 所 有 事物 。 电 话 线 上 的 静电 就 是 一 个 影响 电话 通信 的 鲜 
明 例 子 。 然 而 ， 电 话 通信 通常 都 能 成 功 ， 因 为 即使 存在 噪声 ， 语 音 中 仍 存在 大 量 的 见 余 。 
我 们 要 理解 对 方 的 意思 ， 并 不 需要 听 清 对 方 所 说 的 每 个 词 的 每 个 音节 。 
在 上 述 例子 中 ， 噪 声 是 指 黑夜 中 暗淡 的 光线 以 及 保罗 里 威 尔 距 钟 楼 的 距离 ， 这 两 
个 因素 都 能 让 化 分 辨 不 出 点 亮 的 是 哪 营 提 灯 。 以 下 就 是 朗 福 罗 诗 中 至 关 重 要 的 一 段 : 
哦 ! 他 站 在 与 钟楼 等 高 的 位 置 观察 ， 
一 丝 摄 旭 的 微 光 ， 接 下 来 ， 有 一 苗 灯 亮 了 ! 
他 跳 上 马鞍 ,调转 蕊 头 ， 


徘徊 、 凝 视 ， 直 到 看 清 所 有 的 灯 ， 
钟楼 上 的 第 二 盖 也 灯亮 了 起 来 1! 


那 当 然 不 是 说 保罗 “' 里 威 尔 正在 分 辨 到 底 是 哪 井 灯 先 亮 的 问题 。 


这 里 最 本 质 的 概念 就 是 ， 信 息 是 指 多 个 可 能 性 中 的 一 种 。 例 如 ， 当 我 们 与 一 个 人 交 
痰 的 时 候 ， 我 们 所 说 的 每 个 字 都 是 对 字典 中 所 有 字 的 一 个 选择 。 如 果 我 们 将 所 有 字典 中 
的 字 从 1 到 351482 编号 ， 我 们 可 以 用 数字 准确 地 进行 交谈 ， 而 无 需 使 用 单词 。( 当然 ， 
交谈 双方 都 需要 有 一 本 字典 ， 字 典 上 标注 着 每 个 数字 所 代表 的 是 什么 字 ， 并 且 他 们 还 需 
要 有 足够 的 耐心 。) 


换 名 话说， 所 有 可 以 被 转换 成 对 两 种 或 多 种 可 能 性 的 选择 的 信息 ， 都 可 以 用 比特 来 
表示 。 不 用 说 ， 人 类 有 很 多 形式 的 交流 是 不 能 用 对 非 此 即 彼 的 可 能 性 的 选择 来 表示 的 ， 
但 这 些 交 流 形式 对 我 们 人 类 的 生存 又 是 至 关 重 要 的 。 这 就 是 人 类 为 什么 没有 与 计算 机 之 
间 建 立 起 浪漫 的 关系 的 原因 (无 论 如 何 , 我 们 都 希望 这 种 情况 不 会 发 生 )。 如 果 你 无 法 用 
语言 、 图 画 或 声音 来 表达 某 种 事物 的 时 候 ， 你 就 也 无 法 将 这 个 信息 用 比特 的 形式 来 编码 。 
当然 ， 你 也 不 会 想 去 这 么 做 。 


坚 起 拇指 或 者 不 紧 起 拇指 就 是 一 个 比特 的 信息 。 两 个 人 是 否 竖 起 拇指 -一 就 如 影评 人 
有 罗 杰 “ 艾 伯 特 和 刚 去 世 不 久 的 珍妮 ' 西 斯 科 对 新 影片 给 出 他 们 的 评价 时 那样 -一 传达 了 两 
个 比特 的 信息 (我 们 且 不 论 他 们 对 电影 所 做 了 什么 评价 ; 我 们 所 关心 的 只 是 他 们 的 拇指 )。 
这 里 有 四 种 可 能 性 ， 可 以 用 两 个 比特 位 来 表示 : 


00= 他 们 都 不 喜欢 这 部 电影 

01 = 西 斯 科 讨厌 它 ， 艾 伯 特 喜欢 它 
10 = 西 斯 科 喜 欢 它 ， 艾 伯 特 讨厌 它 
11 = 他 们 都 喜欢 这 部 电影 


第 一 个 比特 位 表示 西 斯 科 的 意见 ， 为 0 表示 西 斯 科 讨 厌 这 个 部 电影 ， 为 1 表示 喜欢 。 同 
样 的 ， 第 二 位 表示 艾 伯 特 的 意见 。 

因此 ， 如 果 你 的 朋友 问 你 :“ 对 于 电影 1mpolite Encounter， 西 斯 科 和 艾 伯 特 的 评论 如 
何 ? ”你 不 必 回 答 “ 西 斯 科 雹 起 了 大 拇指 ， 艾 伯 特 却 没 有 。” 或 者 “ 西 斯 科 喜 欢 这 部 电影 ，: 
而 艾 伯 特 不 喜欢 。” 你 可 以 简短 地 回答 :“ 一 零 。” 只 要 你 的 朋友 知道 哪 一 位 表示 西 斯 科 的 
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人 


意见 ， 哪 一 位 表示 艾 伯 特 的 意见 ， 并 且 知 道 1 表示 坚 起 拇指 ，0 表示 没有 ,你 的 回答 就 会 
容易 理解 。 但 是 ， 前 提 是 你 和 你 的 朋友 都 知道 编码 的 含义 。 


—~ 


I 


我 们 也 可 以 一 开始 就 声明 值 为 1 的 比特 位 表示 没有 竖 起 拇指 ， 信 为 0 的 比特 位 表示 
竖 起 了 ， 这 可 能 有 点 违反 常规 。 通 常 我 们 会 认为 值 为 1 的 比特 表示 赞成 ， 而 值 为 0 的 比 
特 则 表示 反对 ， 但 是 实际 上 这 是 可 以 任意 调换 的 。 只 要 每 个 使 用 代码 的 人 知道 0 和 1 都 
具体 表示 什么 意义 即 可 。 


某 一 位 或 一 连 串 比特 位 所 表示 的 意义 通常 是 和 上 下 文 有 关 的 。 系 在 一 棵 橡树 上 的 黄色 
丝带 可 能 仅仅 是 对 于 把 它 系 在 那里 的 人 和 希望 在 那里 看 到 它 的 人 才 有 意义 。 改 变 丝带 的 颜 
色 、 系 丝带 的 树 或 者 系 丝带 的 日 期 ， 它 就 可 能 成 为 一 块 没 有 任何 意义 的 破 布 。 同 样 ， 想 从 
西 斯 科 和 艾 伯 特 的 手势 中 得 到 有 用 的 信息 ， 我 们 至 少 需要 知道 他 们 讨论 的 是 哪 部 电影 。 


如 果 你 保留 了 一 份 西 斯 科 和 艾 伯 特 对 于 电影 的 评价 和 投票 结果 ， 你 就 可 以 在 反映 他 
们 意见 的 比特 信息 中 再 添加 一 个 比特 位 ， 来 表示 你 自己 的 看 法 。 添 加 第 三 个 比特 位 将 使 
得 其 代表 的 信息 可 能 性 扩展 到 8 种 : 


000 = 西 斯 科 讨 
001 = 西 斯 科 讨 


厌 它 ， 艾 伯 特 讨厌 它 ， 我 讨厌 

厌 它 ， 艾 伯 特 讨厌 它 ， 我 喜欢 
010 = 西 斯 科 讨 厌 它 ， 艾 伯 特 喜欢 它 ， 我 讨厌 
011 = 西 斯 科 讨 厌 它 ， 艾 伯 特 喜欢 它 ， 我 喜欢 它 
100 = 西 斯 科 喜 欢 它 ， 艾 伯 特 讨厌 它 ， 我 讨厌 它 
101 = 西 斯 科 喜 欢 它 ， 艾 伯 特 讨厌 它 ， 我 喜欢 它 
110 = 西 斯 科 喜欢 它 ， 艾 伯 特 喜欢 它 ， 我 讨厌 它 
111 = 西 斯 科 喜 欢 它 ， 艾 伯 特 喜欢 它 ， 我 喜欢 它 


利用 二 进 制 表示 信息 的 一 个 额外 的 好 处 就 是 我 们 可 以 清楚 地 知道 我 们 是 否 已 经 想到 
了 所 有 的 可 能 性 。 我 们 知道 在 这 种 情况 下 有 且 仅 有 8 种 可 能 性 ， 不 多 也 不 少 。 如 果 用 3 
个 比特 位 ， 只 能 从 0 数 到 7， 后 面 不 会 再 有 其 他 的 三 位 二 进 制 数 存在 了 。 
在 描述 西 斯 科 和 艾 伯 特意 见 的 比特 位 中 ， 你 可 能 一 直 在 考虑 一 个 非常 重要 而 且 令 人 
不 安 的 问题 , 这 个 问题 就 是 : 对 于 李 纳 德 马丁 的 “电影 及 电视 指南 ”我 们 该 怎么 办 呢 ? 
毕竟 李 纳 德 ， 马丁 不 用 手指 来 评价 电影 ， 他 用 的 是 一 种 更 传统 的 星 级 系统 来 评价 。 


[守信 计 


CT GUI 


要 想 知道 需 多 少 个 马丁 比特 ， 首 先 必须 了 解 这 个 系统 的 一 些 情况 。 马 丁 给 电影 的 评 
价 是 1~4 颗 星 ， 并 且 中 间 可 以 有 半 颗 星 ， 为 了 好 玩 ， 实 际 上 他 不 会 给 电影 只 评 一 颗 星 ， 


而 是 用 “BOMB ( 炸弹》 来 代替 。 这 里 总 共有 7 种 可 能 性 ， 也 就 意味 着 我 们 可 以 用 三 个 比 
特 位 来 表示 某 个 评价 等 级 了 : 

000 = BOMB 

001= 女 1/2 

010= 三 

011= 支 克 1/2 

100= 妈妈 女 

101 = 克 廊 支 1/2 

110= 让 让 真 丰 
你 可 能 会 问 :“111 呢 ? ”在 这 里 ， 这 个 编码 不 代表 任何 意义 。 它 没有 定义 。 如 果 二 进 制 
代码 111 被 用 来 表示 马丁 的 评价 , 那么 你 就 会 知道 一 定 是 出 错 了 ( 计算 机 有 可 能 会 出 现 这 
样 的 错误 ， 因 为 人 不 会 给 出 这 样 的 评分 )。 

之 前 提 到 过 ， 当 我 们 用 两 个 比特 位 来 表示 西 斯 科 和 艾 伯 特 的 评价 时 ， 左 边 一 位 表示 


个 


我 们 就 得 


的 是 西 斯 科 的 意见 ， 右 边 一 位 表示 的 则 是 艾 伯 特 的 意见 。 在 上 述 马 丁 的 家 


分 系统 中 ， 每 


单独 的 比特 位 都 有 确定 的 意义 吗 ? 是 的 ,当然 有 。 如 果 将 比特 码 的 数值 加 2, 再 除 以 2， 
到 了 马丁 评分 中 对 应 的 星星 的 数量 。 但 这 仅仅 是 由 于 我 们 以 一 种 合乎 人 们 对 数 


字 含 义 体验 的 方式 定义 了 编码 。 


000 
001 
010 
011 
101 
110 


111 


以 要 每 个 人 都 明白 它 的 意义 ， 这 个 编码 就 与 先前 的 编码 同 档 


我 们 同样 也 可 以 将 编码 作 如 下 定义 : 
二 交友 次 

= 女 1/2 

= 女友 1/2 

= 六 六 女友 

= 女 交 次 1/2 

二 女友 

= BOMB 


有效。 


如 果 马 丁 遇 到 
会 有 足够 的 编码 来 表示 


1 了 一 部 甚至 连 一 颗 星 都 不 值得 给 的 电影 ， 他 会 给 出 半 颗 星 。 他 也 当 
星 选项 。 此 时 ， 编 码 会 像 下 面 这 样 定 义 : 
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一 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
| 


000 = MAJOR BOMB 


001 = BOMB 
010= 支 1/2 
011= 交友 
100= 支 太 1/2 
101= 交 太 太 
110= 支 克 克 1/2 
111= 次女 交 克 


但 是 ， 如 果 他 直到 了 一 部 连 半 颗 星 都 不 值得 给 的 电影 ， 他 就 决定 给 它 没有 星 的 级 别 
(AIOMIC BOMB? )， 这 时 他 就 得 再 添加 一 个 比特 位 了 。 因 为 已 经 没有 三 个 比特 位 的 代 
码 可 以 用 了 。 


《娱乐 周刊 》 杂 志 常 党 举行 一 些 评级 活动 ， 评 级 的 对 象 除了 电影 之 外 还 有 电视 节目 、 
CD、 书 籍 、CD-ROM、 网 站 等 其 他 一 些 东 西 。 等 级 的 范围 是 从 A+~F (尽管 似乎 只 有 波 
利 : 每 尔 的 电影 才能 堪 此 殊荣 )。 计 算 一 下 ,一 共有 13 个 可 能 的 等 级 。 我 们 需要 用 4 个 
比特 位 来 表示 这 些 等 级 。 


0000 = 下 
0001 = D- 
0010=D 
0011 = D+ 
0100=C- 
0101 =C 
0110 = C+ 
0111 = B- 
1000=B 
1001 = B+ 
1010=A- 
1011 =A 
1100= A+ 


这 里 我 们 有 3 个 编码 没有 用 到 ， 即 1101，1110 和 1111， 加 上 这 3 个 总 共有 16 个 编码 。 


无 论 何 时 我 们 痰 到 比特 ,通常 所 指 的 都 是 一 定数 目的 比特 位 。 我 们 拥有 的 比特 位 数 
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越 多 ， 所 能 表示 的 不 同 可 能 性 就 越 多 。 


当然 , 在 十 进 制 中 也 是 同样 的 道理 。 例 如 ,电话 号 码 的 区 号 有 多 少 位 呢 ? 区 号 共有 3 
位 十 进 制 数 ， 如 果 所 有 的 区 号 都 使 用 的 话 ( 实际 上 我 们 并 没有 都 使 用 ， 但 这 里 不 考虑 这 
个 问题 ), 一 共 就 会 有 10;， 即 1000 个 号 码 , 即 000 ~ 999。 区 号 是 212 的 7 位 电话 号 码 会 
有 多 少 种 可 能 呢 ? 10 ， 即 10,000,000 个 。 区 号 是 212， 并 且 以 260 开头 的 电话 号 码 会 有 
多 少 个 呢 ?10+， 即 10,000 个 。 


类 似 的 ， 在 二 进 制 中 ， 可 能 有 的 编码 数 等 于 2 的 整数 次 蝇 ， 其 知 指 数 就 是 比特 位 的 
位 数 。 


比特 位 数 
5 25= 32 
6 26= 64 
7 27= 128 
28= 256 
2?= 512 


每 增加 一 个 比特 位 就 会 将 编码 的 数量 增加 一 倍 。 


如 果 已 知 所 要 用 到 编码 的 数量 ， 如 何 计 算 需 要 多 少 比特 位 呢 ? 换 名 话说， 在 上 表 中 ， 
如 何 才能 由 码 字数 反 推 出 比特 位 数 呢 ? 


所 要 用 到 的 方法 叫做 以 2 为 底 的 对 数 运算 ， 对 数 运算 是 指数 运算 的 逆 运 算 。 我 们 知 
道 2 的 7 次 竺 等 于 128。 那 么 以 2 为 底 的 128 的 对 数 就 是 7。 用 数学 符号 来 表示 : 
2 =128 
等 价 于 ; 
logz128 = 7 


因此 ， 如 果 以 2 为 底 的 128 的 对 数 是 7， 以 2 为 底 256 的 对 数 就 是 8。 那 么 ， 以 2 为 
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一 编码 一 隐匿 在 计算 机 软 硬 人 


底 200 的 对 数 是 多 少 呢 ” 大 约 是 7.64， 但 实 阿 


背后 的 语 


二 
再 


KR 上 并 


需要 知道 具 


体 的 值 。 如 果 我 们 要 


LD 


二 进 制 来 表示 200 种 不 同 的 事物 ， 共 需要 8 个 比特 位 。 
比特 通常 无 法 从 日 常 观察 中 找到 , 它 深 藏 于 电子 设备 中 。 我 们 看 不 到 压缩 磁盘 (CD )、 
数字 手表 或 计算 机 中 被 编码 的 比特 ， 但 有 时 比特 也 会 清晰 地 呈现 在 我 们 眼前 。 
下 面 就 是 一 个 例子 。 如 果 你 有 一 台 相 机 是 使 用 35 毫米 胶片 的 ， 观 察 一 下 它 的 卷轴 。 
这 样 拿 住 胶卷 : 
你 可 以 看 到 像 国 际 象棋 棋盘 那样 银 黑 交错 排列 的 方 格 , 这 些 方 格 在 图 中 已 经 用 数字 1~ 12 
进行 了 标注 。 这 叫做 DX 编码 , 这 12 个 方 格 实际 上 是 12 个 比特 位 。 一 个 银色 的 方 格 代表 
值 为 1 的 比特 ,一 个 黑色 的 方 格 代 表 值 为 0 的 比特 。 方 格 1 和 方 格 7 通常 是 银色 的 ( 代 
表 1 为 
这 些 比 特 代表 什么 意思 呢 ?” 你 可 能 会 知道 ， 有 些 胶片 比 其 他 胶片 对 光 更 敏感 些 。 这 
种 对 光 的 敏感 程度 称 做 胶片 速度 。 人 们 会 说 某 种 对 光 非 常 敏 感 的 胶片 “很 快 "， 那 是 因为 
这 种 胶片 的 曝光 速度 极 快 。 胶 片 的 曝光 速度 是 由 美国 标准 协会 ASA ( American Standards 
Association ) 来 制定 等 级 的 。 最 常用 的 等 级 有 100、200 和 400。ASA 等 级 不 仅 以 十 进 制 
数字 的 形式 印 在 胶卷 的 外 包装 和 瞳 盒 上 ， 它 还 以 比特 的 形式 进行 了 编码 。 
胶卷 总 共有 24 个 ASA 等 级 ， 它 们 是 : 
25 32 40 
50 64 80 
100 125 160 
200 250 320 
400 500 640 
800 1000 1250 
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1600 2000 2500 
3200 4000 5000 
要 对 ASA 等 级 进行 编码 需要 多 少 个 比特 位 呢 ? 管 案 是 5 个。 我 们 知道 2 是 16, 比 24 要 
小 。2 是 32， 而 这 个 数 又 超过 了 所 需 的 码 字数 。 
与 胶片 速度 对 应 的 比特 值 如 下 表 所 示 。 
方 格 2 | 方 格 3 


0 25 


| 0 | 0 0 1 32 
和 0 
1 0 

Ee 

| 
0 1 0 100 

一 一 0 0 1 125 
0 1 1 160 
0 1 0 200 
0 0 1 250 
0 1 1 320 
1 1 0 400 
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一 | 一 | 一 | 一 | 一 | 一 | 一 | 一 | 一 | 一 
一 | 一 | 一 | 一 | 一 Ol 一 


大 多 数 现代 的 35 毫米 照相 机 胶片 都 使 用 这 些 码 字 《 除 了 那些 要 手动 进行 曝光 的 相机 
和 具有 内 置式 测 光 表 但 需要 手动 设 定 曝光 速度 的 相机 以 外 )。 如 果 你 观察 一 下 照相 机 内 部 
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A 


放 胶 卷 的 地 方 ， 就 会 发 现在 胶卷 简 内 部 有 6 个 金属 的 触 点 ， 对 应 着 胶片 的 金属 方 格 (1 ~ 
6 号 )。 银色 方 格 实际 上 是 胶卷 暗盒 中 的 金属 ， 即 导体 ; 涂 有 颜料 的 黑色 方 格 ， 是 绝缘 体 。 


照相 机 中 的 电路 产生 一 个 电流 流入 方 格 1, 方块 1 通常 是 银色 的 。 这 支 电流 有 可 能 流 
经 (也 可 能 未 流 经 ) 方 格 2~6 上 的 5 个 触 点 ， 这 取决 于 方 格 是 纯 银 还 是 涂 有 颜料 的 。 这 
样 , 如 果 照 相机 在 触 点 4 和 触 点 5 上 检测 到 了 电流 , 而 在 触 点 2、3 和 6 上 却 没有 检测 到 ， 
那么 这 个 胶片 的 速度 就 是 400 ASA。 这 样 ， 照 相机 就 可 以 据 此 来 调整 胶片 的 曝光 时 间 了 。 


假设 胶片 速度 是 50、100、200 或 400 ASA， 那 么 廉价 的 相机 就 只 需 读 取 方 格 2 和 方 
格 3 上 的 电流 。 


多 数 照相 机 不 需要 读 取 或 使 用 方 格 8 ~ 12。 方 格 8、9 和 10 被 用 来 对 这 卷 胶卷 进行 编 
码 , 方 格 11 和 方 格 12 指出 曝光 范围 ( exposure latitude )， 这 取决 于 胶片 是 用 于 黑白 冲洗 、 
彩色 冲洗 ， 还 是 做 彩色 幻灯 片 。 


也 许 最 常见 的 二 进 制 数 的 表现 形式 就 是 无 所 不 在 的 通用 产品 代码 (UPC，Universal 
Product Code )， 这 个 小 条 形 码 出 现在 差不多 我 们 日 常 所 购买 的 所 有 商品 的 包装 上 。UPC 已 
经 成 为 计算 机 逐步 进入 人 们 日 常生 活 的 标志 之 一 。 

尽管 UPC 经 常会 使 人 们 瞎 猜 疑 ， 但 是 它 其 实 是 无 束 的 。 使 用 它 的 初衷 仅仅 是 为 了 实 
现 零售 业 的 结算 和 存货 管理 的 自动 化 ， 而 且 它 在 这 方面 的 应 用 也 很 成 功 。 当 UPC 与 一 个 
设计 精巧 的 结账 系统 结合 使 用 时 ， 顾 客 会 得 到 一 张 逐 项 开 列 的 消费 清单 ， 这 点 是 传统 的 
现金 出 纳 员 所 无 法 做 到 的 。 


有 趣 的 是 ，UPC 也 是 二 进 制 码 , 尽管 乍 看 起 来 它 并 不 太 像 。 将 UPC 解码 并 看 看 UPC 
到 底 是 怎样 工作 的 ， 就 明白 了 。 


在 最 常见 的 形式 中 ，UPC 是 由 30 条 不 同 宽度 的 垂直 黑色 条 纹 组 成 的 ， 它 们 的 间隔 宽 
度 也 不 同 ， 条 纹 下 面 标 有 数字 。 例 如 ， 以 下 是 Campbell 公司 出 品 的 10 3/4 盎司 的 镀 装 鸡 


好 82 


9 二进制 数 


了 
} 


我 们 要 试 着 将 条 形 码 形象 地 看 成 是 细 条 和 黑 条 、 宗 间隙 和 宽 间 阶 的 排列 ， 事 实 上 ， 
这 就 是 观察 条 形 码 的 一 种 方式 。 在 UPC 中 ， 黑 色 条 纹 有 四 种 不 同 的 宽度 ， 宽 条 纹 的 宽度 
分 别 是 最 细 条 纹 宽度 的 两 售 、 三 倍 或 四 倍 。 同 样 ， 宽 间隔 的 宽度 分 别 是 最 窄 间隔 宽度 的 
两 倍 、 三 倍 或 四 倍 。 


但 是 ， 另 一 种 解读 UPC 的 方式 就 是 将 它们 看 做 一 列 比 特 位 。 记 住 整个 条 形 码 不 是 在 
收银 台 的 扫描 仪 所 “看 到 ”的 那样 。 扫 描 仪 所 读 到 的 并 不 是 下 面 一 排 的 数字 ， 因 为 这 需 
要 更 精密 的 光学 识别 (OCR，Optical Character Recognition ) 技术 。 扫 描 仪 只 识别 整个 条 
形 码 的 一 条 窄带 ， 条 形 码 做 得 很 大 是 为 了 便于 结算 台 的 操作 人 员 用 扫描 仪 对 准 。 扫 描 仪 
所 看 到 的 那 一 个 UPC 断面 可 以 这 样 表示 : 


8 本 有 
看 起 来 与 莫 尔 斯 码 很 像 ， 不 是 吗 ? 


当 计 算 机 从 左 向 右 扫 描 这 个 信息 时 ， 它 会 首先 给 遇 到 的 第 一 个 黑 条 分 配 一 个 值 为 1 
的 比特 ， 给 与 这 个 黑 条 相 邻 的 白色 间隙 分 配 一 个 值 为 0 的 比特 。 随 后 的 条 纹 和 间 阶 被 读 
做 一 行 中 的 一 系列 比特 ， 每 个 系列 的 比特 可 以 是 1 位 、2 位 、3 位 或 4 位 ， 而 这 个 位 数 取 
决 于 条 纹 和 空隙 的 宽度 。 本 例 中 扫描 仪 所 扫描 到 的 条 形 码 与 比特 位 之 间 的 关系 可 以 简单 
的 表示 为 : 

1 省 1 ES 


1010G81161611800185118989100811918861181986611016181911189181186811811011891881116]106116168981890161 


因此 , 整个 UPC 只 不 过 是 一 串 95 位 二 进 制 数 ,在 本 例 中 , 这 些 比特 可 以 做 如 下 分 组 。 


前 3 位 通常 都 是 101， 这 就 是 最 左边 的 护 线 ， 它 帮助 计算 机 扫描 仪 定位 。 从 护 线 中 ， 
扫描 仪 可 以 确定 代表 单个 比特 的 条 和 间 党 的 宽度 是 多 少 。 否 则 ， 所 有 包装 上 的 UPC 就 都 
得 采用 指定 的 大 小 了 。 


最 左边 的 护 线 之 后 是 6 组 比特 串 ,每 华 含 有 7 个 比特 位 。 其 中 每 一 组 都 可 以 是 数字 0~ 
9 的 编码 ， 后面 我 会 做 一 个 简短 的 说 明 。 接 下 来 是 一 个 5 比特 位 的 中 间 护 线 ， 这 是 一 个 固 
定 的 模式 ( 始终 是 01010 )， 它 是 一 个 内 置式 的 检 错 码 。 如 果 计 算 机 扫描 仪 没有 在 应 有 的 位 
置 找 到 中 间 护 线 , 它 就 无 法 破解 UPC 码 。 这 条 中 间 护 线 是 用 来 预防 条 形 码 被 自 改 或 被 印 错 
的 一 种 方法 。 
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比特 意义 
101 最 左边 的 护 线 
0001101 
0110001 
0011001 
0001101 
0001101 
0001101 
01010 中 间 的 护 线 
1110010 
1100110 
1101100 
1001110 
1100110 
1000100 
101 最 右边 的 护 线 
中 间 护 线 后 面 仍然 是 6 组 比特 串 ， 每 组 中 含有 7 个 比特 位 。 之 后 是 最 右边 的 护 线 ， 
最 右边 的 护 线 通 常 都 为 101。 最 右边 的 护 线 可 以 实现 UPC 的 反 向 扫描 (也 就 是 从 右 到 左 
扫描 )， 这 一 点 我 们 将 在 后 面 解释 。 


左边 的 数字 


右 返 的 数字 


因此 ， 整 个 UPC 对 12 个 数字 进行 了 编码 。UPC 的 左边 含有 6 个 编码 数字 ， 每 个 数 
字 占 有 7 个 比特 位 。 你 可 以 利用 如 下 的 表格 来 解码 。 


左边 的 编码 
0001101=0 0110001=5 
0011001=1 0101111=6 
0010011 = 2 0111011=7 
0111101 =3 0110111 = 8 
0100011 = 4 0001011=9 


注意 ， 这 里 每 个 7 位 编码 都 是 以 0 开头 ， 以 1 结尾 的 。 如 果 扫 措 仪 遇 到 了 一 个 位 于 左边 
的 7 位 编码 ， 这 个 编码 是 以 1 开头 以 0 结尾 的 ， 那么 它 就 知道 自己 没有 将 UPC 正确 地 读 
入 或 者 条 形 码 被 自 改 了 。 男 外 我 们 还 注意 到 每 组 编码 都 仅 有 两 组 连续 为 1 的 比特 位 ， 这 
就 暗示 每 个 数字 对 应 着 UPC 码 中 的 两 个 垂直 条 纹 。 


你 也 会 发 现 , 上 表 中 每 组 编码 都 含有 奇数 个 1。 这 是 另 一 种 检查 错误 和 一 致 性 的 方法 ， 


人 = 


称 为 奇偶 校 验 。 如 果 一 组 比特 位 中 含有 偶数 个 1， 它 就 称 为 偶 校 验 ; 如 果 含 有 奇数 个 1， 
Bb 么 它 就 称 为 奇 校 验 。 这 样 看 来 ， 所 有 这 些 编码 都 拥有 奇 校 验 。 


破解 右边 的 6 组 7 位 编码 要 用 到 下 表 。 
右边 的 编码 
1110010=0 1001110=5 
1100110=1 1010000=6 
1101100=2 1000100=7 
1000010=3 1001000 =8 
1011100=4 1110100=9 


这 些 编码 都 是 之 前 编码 的 补 码 : 之 前 出 现 0 的 地 方 , 现在 都 换 成 了 1， 反之 亦 然 。 这 些 编 
码 都 是 以 1 开头 ， 以 0 结尾 的 。 除 此 之 外 ， 每 组 编码 都 含有 假 数 个 1， 属 于 偶 校 验 。 


现在 ,我们 就 可 以 解读 UPC 了。 运用 以 上 两 个 表格 , 我 们 可 以 确定 ，Campbeli 公司 
的 10 3/4 冀 司 钠 装 鸡 汁 面 汤 包 上 的 12 个 数字 为 : 


0 51000 01251 7 


太 令 人 失望 了 。 就 如 你 所 看 到 的 ， 这 与 UPC 下 面 印刷 的 数字 完全 相同 〈 这 样 做 是 很 有 意 
义 的 ， 在 扫描 仪 由 于 某 种 原因 无 法 解读 出 条 形 码 时 ， 收 银 员 就 可 以 手动 输入 这 些 数字 ， 
富 无 疑问 你 也 看 到 过 这 一 幕 )。 我 们 没有 必要 了 解 解码 的 全 部 过 程 ， 况 且 ， 我 们 也 无 法 从 
中 解码 出 任何 秘密 信息 。 不 过 , 关于 UPC 的 解码 工作 已 经 没有 什么 可 做 了 , 那 30 根 竖 条 
已 经 变 成 了 12 个 数字 。 


第 一 个 数字 (在 这 里 是 0 ) 被 称 为 数字 系统 符 。0 意味 着 这 是 一 个 常规 的 UPC。 如 果 
UPC 出 现在 杂货 店 中 那些 需要 称 重 的 商品 上 ， 例 如 肉 、 农 产品 , 这 个 编码 就 会 是 2。 票 
的 UPC 的 第 一 个 数字 通常 是 5。 


接 下 来 的 5 个 数字 表示 制造 商 编码 。 这 种 情况 下 ，51000 就 是 Campbell 公司 的 编码 。 
所 有 Campbell 公司 的 产品 都 有 这 个 编码 。 后 面 的 5 位 代码 (01251 ) 是 这 个 公司 的 某 种 商 
品 的 编码 ， 上 例 中 这 个 数字 就 是 指 10 3/4 将 司 铅 装 鸡 守 面 。 只 有 和 制造 商 编 码 同 时 出 现 
的 时 候 这 个 编码 才 有 意义 。 另 一 个 公司 的 鸡 计 面 会 有 另外 一 个 编码 ,01251 在 另外 一 个 公 
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司 可 能 是 指 一 种 完全 不 同 的 产品 。 
与 大 家 通常 的 想法 相反 ，UPC 不 包含 物品 的 价格 信息 。 价 格 信息 可 以 从 商店 使 用 的 
与 该 扫描 仪 相连 的 计算 机 中 检索 到 。 


最 后 一 个 数字 (在 这 里 是 7 ) 称 为 模 校 验 字符 。 这 个 字符 可 用 来 进行 另外 一 种 错误 检 
验 。 为 了 了 解 它 是 如 何 工作 的 ,我们 将 前 11 个 数字 (在 这 个 例子 中 是 051000 01251 ) 各 
用 一 个 字母 来 代替 : 

A BCDEF GHIJK 
然后 ， 计 算 下 式 的 值 : 


3x(A+TC+E+G+I+K)+(B+D+F+H+D 


从 离 这 个 值 最 近 并 且 大 于 或 等 于 它 的 一 个 10 的 整 倍数 中 减 去 它 ， 其 结果 称 为 模 校 验 字符 
( modulo check character )。 在 Campbell 鸡 汁 面 的 例子 中 ， 有 : 


3x(0+1+0+0+2+1)+(S+0+0+1+5)=3x4+11=23 
紧 挨 23 并 大 于 或 等 于 23 的 10 的 整 倍数 是 30， 因 此 : 
30 一 23 =7 
这 就 是 印 在 外 包装 上 并 以 UPC 形式 编码 的 模 校 验 字 符 ， 这 是 一 种 元 余 措 施 。 如 果 扫 
描 仪 没有 扫描 到 与 计算 机 计算 结果 相同 的 模 校 验 字 符 ， 那 么 计算 机 就 视 这 个 UPC 无 效 。 


通常 情况 下 ， 要 表示 0~ 9 的 十 进 制 数字 只 需要 4 个 比特 位 就 是 够 了 。UPC 中 每 个 数 
字 用 了 7 个 比特 位 。 这 样 ，UPC 总 共用 了 95 个 比特 位 来 表示 11 个 有 效 的 十 进 制 数 。 实 
际 上 ，UPC 中 还 有 空白 位 置 (相当 于 9 个 0 比特 ), 它们 位 于 左 、 右 护 线 的 两 侧 。 这 就 意 
味 着 , 整个 UPC 需要 113 个 比特 位 来 编码 11 个 十 进 制 数 , 平均 每 个 十 进 制 数 所 用 的 比特 
位 超过 了 10 个 ! 


如 我 们 所 看 到 的 ， 有 部 分 匈 余 对 于 检 和 错 来 讲 是 必要 的 。 这 种 商品 编码 如 果 能 够 被 顾 
客 用 笔 轻易 地 改动 ， 那 么 这 种 产品 编码 措施 也 就 没有 任何 意义 了 。 


UPC 可 以 从 两 个 方向 读 ， 这 一 点 是 非常 方便 的 。 如 果 扫 描 装 置 解码 的 第 一 个 数 是 符 
合 偶 校 验 ( 即 7 位 编码 中 有 偶数 个 1 ) 的 ， 扫 描 仪 就 会 知道 ， 它 正 从 右 向 左 扫 描 UPC 码 。 
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计算 机 就 会 使 用 如 下 表 来 解码 。 

递 向 扫描 时 右边 教 字 的 编码 
0100111=0 0111001 =5 
0110011=1 0000101=6 
0011011 =2 0010001 =7 
0100001 =3 0001001= 8 
0011101 =4 0010111 =9 

以 下 是 对 左边 数字 的 解码 表 。 

北向 扫描 时 左边 数字 的 编码 
1011000=0 1000110=5 
1001100=1 1111010=6 
1100100=2 1101110=7 
1011110=3 1110110=8 
1100010=4 1101000=9 


所 有 这 些 7 位 编码 都 与 由 左 向 右 扫描 时 得 到 的 UPC 完全 不 同 。 这 里 不 会 有 模棱两可 
的 现象 存在 。 

在 这 本 书 中 我 们 是 从 莫 尔 斯 码 开始 接触 编码 的 ， 莫 尔 斯 码 是 由 点 和 划 组 成 的 ， 且 点 
和 划 之 间 由 一 定 的 时 间 间 隔 分 开 。 尽 管 莫 尔 斯 码 乍 看 上 去 并 不 像 是 由 0 和 1 组 成 的 ， 然 
而 它们 却 是 等 价 的 。 

回顾 一 下 莫 尔 斯 码 的 编码 规则 : 划 的 长 度 等 于 点 长 度 的 三 倍 ; 单个 字母 内 ， 点 或 划 
之 闻 以 长 度 与 点 相等 的 空格 来 分 开 ; 单词 内 的 各 个 字母 之 间 用 长 度 等 于 划 的 空格 分 隔 ; 
各 单词 之 间 由 长 度 等 于 两 倍 的 划 的 空格 分 开 。 

让 我 们 将 分 析 简 化 一 些 ， 假 设 一 个 划 的 长 度 是 点 长 度 的 两 倍 ， 而 不 是 三 倍 。 这 就 意 
味 着 一 个 点 就 是 一 个 值 为 1 的 比特 位 ， 一 个 划 是 两 个 值 为 1 的 比特 位 ， 空 格 则 是 值 为 0 
的 比特 位 。 


下 面 是 第 2 章 中 莫 尔 斯 码 的 基本 表 。 
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本 


以 下 是 转化 为 比特 的 结果 。 


71911 多 1 信和 L11819 18101106 

11018186 1181198 181810118 
1818118109 1101181108 11016101100 
110118160 i191191101060| Y |ii9181101108 
i1009181869 | Q liienigisiig8| z [ii811819188 


注意 ， 这 里 所 有 编码 都 是 以 1 开头 ， 以 两 个 0 结尾 。 结 尾 处 的 两 个 0 代表 单词 内 各 
个 字母 之 间 的 空格 。 单词 之 间 的 空格 编码 则 是 另外 一 对 0。 因 此 , 在 莫 尔 斯 码 中 “hi there” 
通常 是 这 样 表示 的 : 


第 和 当当 逢 当归 i 
但 是 ， 当 莫 尔 斯 码 采 用 比特 来 表示 的 时 候 ， 看 起 来 就 像 UPC 的 一 个 截面 。 


和 大 国生 
1610181001061998011681018181601801011910010000 


用 比特 的 形式 表示 布 莱 叶 盲文 比 表示 莫 尔 斯 码 容易 得 多 。 布 菜 叶 盲文 是 6 位 编码 。 
其 中 的 每 一 个 字母 都 是 由 6 个 点 组 成 的 ， 这 些 点 可 能 是 凸 起 的 ， 也 可 能 是 不 凸 起 的 。 就 
如 同 在 第 3 章 中 所 提 到 的 那样 ， 这 些 点 通常 用 数字 1~ 6 编号。 
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OO 
:OO 


和 


3O00Os 
例如 ， 单 词 “code” 用 布 莱 叶 盲文 可 以 这 样 表示 : 


澡 昌 本: 币 蜗 妆 : 
rr 


En 


+ » 


如 果 突 起 的 点 代表 1， 平 坦 的 点 代表 0， 则 在 布 莱 叶 讶 文中， 每 个 符号 都 可 以 用 6 个 
比特 的 二 进 制 代码 来 表示 。 单 词 “code” 中 的 四 个 布 莱 叶 字母 符号 可 以 简单 地 写成 : 


100100 101010 100110 100010 


这 里 ， 最 左边 的 一 位 对 应 编号 为 1 的 位 置 ， 最 右边 的 一 位 对 应 编号 为 6 的 位 置 。 


在 本 书后 面 的 章节 可 以 看 到 ， 比 特 可 以 表示 文字 、 图 片 、 声 音 、 音 乐 、 电 影 ， 也 可 
以 表示 产品 编码 、 胶 片 速度 、 影 评 结果 、 英 国 军 队 的 入 侵 ， 以 及 心爱 之 人 的 意图 。 但 是 ， 
从 根本 来 说 ， 比 特 是 数字 。 在 用 比特 表示 其 他 信息 的 时 候 我 们 所 要 做 的 就 是 计算 有 多 少 
种 可 能 性 。 这 决定 了 我 们 需要 的 比特 位 数 ， 以 便 每 种 可 能 性 都 可 以 分 配 到 一 个 编号 。 


比特 在 逻辑 学 中 也 很 重要 。 逻 辑 学 是 哲学 和 数学 的 奇特 融合 ， 其 主要 目的 就 是 确定 
某 个 陈述 是 真 还 是 假 。 真 和 假 同 样 可 以 表示 为 1 和 0。 
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什么 是 真理 ? 亚 里 士 多 德 认 为 真理 是 与 逻辑 相关 的 某 种 事物 。 《工具 论 》( 可 以 追溯 
到 公元 前 4 世纪 ) 这 本 书 收集 了 他 的 理论 ， 这 也 是 最 早 在 逻辑 上 做 出 全 面 阐述 的 著作 。 
对 于 十 希腊 人 来 说 ， 还 辑 是 在 追求 真理 的 过 程 中 的 一 种 分 析 方法 ， 因 此 它 被 人 们 认为 是 
一 种 哲学 形式 。 亚 里 士 多 德 的 逻辑 学 基础 是 三 段 论 法 。 最 著名 的 三 段 论 法 (但 是 这 个 三 
段 论 却 并 没有 出 现在 亚 里 士 多 德 的 著作 中 ) 是 : 


所 有 男人 都 必 有 一死 ; 
苏 格 拉 底 是 男人 ; 
因此 ， 苏 格拉 底 必 有 一 死 。 


在 三 段 论 中 ， 首 先 假 定 两 个 条 件 是 正确 的 ， 然 后 再 通过 这 两 个 条 件 推断 出 结论 。 


苏 格 拉 底 之 死 这 种 结论 似乎 太 简单 了 ， 然 而， 三 段 论 的 形式 其 实 是 多 种 多 样 的 。 例 
如 ， 以 下 两 个 由 19 世纪 的 数学 家 查尔斯 . 道奇 森 〈 也 被 人 们 称 为 刘易斯 卡 罗 尔 ) 提出 


的 条 件 : 


所 有 哲人 都 是 符合 逻辑 的 ; 
一 个 没有 有 还 辑 的 人 总 是 非常 顽固 的 。 
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上 述 条 件 的 推论 一 点 也 不 明显 〈 结论 是 “一 些 顽 固 的 人 不 是 哲人 。” 注 意 ， 这 里 “一 
”这 个 词 的 出 现 完全 是 意料 之 外 的 )。 


在 过 去 的 两 千 多 年 里 ， 数 学 家 们 都 压制 着 亚 里 十 多 德 的 逻辑 学 ， 并 试图 用 数学 符号 
和 算 子 限制 它 的 发 展 。19 世纪 前 期 ,唯一 涉足 这 个 领域 的 人 就 是 莱 布 尼 茨 (1648-1716 ) ， 
他 早年 涉足 了 逻辑 学 ， 而 后 转移 到 了 其 他 兴趣 上 《例如 ， 与 牛顿 在 同一 时 期 ， 独 立 发 明 
微 积分 )。 

而 后 乔治 ' 布尔 出 现 了 。 


乔治 布尔 于 1815 年 出 生 于 英格兰 ,降临 到 了 这 个 对 于 他 来 
说 充满 不 公 的 世界 。 乔 治 的 父亲 是 个 鞋 碧 ,母亲 曾经 做 过 女 佣 ， 
因此 ， 按 常理 在 当时 英国 森严 的 等 级 制度 下 ， 他 基本 上 不 会 做 出 
什么 有 别 于 父辈 们 的 事业 。 但 是 他 凭借 着 勇于 探究 的 精神 以 及 父 
亲 的 帮助 (乔治 的 父亲 对 科学 、 数 学 和 文学 都 有 浓厚 的 兴趣 )， 乔 
治 在 年 少 的 时 候 就 接受 了 良好 的 教育 ， 而 这 本 应 是 上 流 社会 中 的 
男孩 子 们 才能 享有 的 特权 。 他 学 习 了 拉丁 语 、 希腊 语 和 数学 。1849 
年 ， 布 尔 凭借 着 他 早期 在 数学 研究 上 的 论文 成 为 了 爱尔兰 利克 市 
皇后 书院 的 数学 系 首席 教授 。 


19 世纪 中 叶 的 一 些 数学 家 一 直 在 研究 逻辑 的 数学 定义 ( 其 中 最 著名 的 是 奥 古 斯 
特 ' 德 摩根 )， 但 在 理论 上 有 着 实际 突破 的 却 是 布尔 。 首 先是 一 部 短篇 著作 《人 逻辑 的 数 
学 分 析 一 一 关于 演绎 推理 的 一 篇 随笔 》( The Mathematical Analysis of Logic, Being an 
Essay Towards a Calculus of Deductive Reasoning，1847 年 )， 而 后 是 一 篇 更 长 且 更 宏大 
的 著作 《思维 规律 的 研究 一 一 逻辑 与 概率 数学 理论 的 基础 》( 4n JInvestigation of the Laws 
of Thought on Which Are Founded the Mathematical Theories of Logic and Probabilities, 
1854 年 )， 通 称 《 思维 规律 》( The Laws of Thought )。 布 尔 死 于 1864 年 ， 他 由 于 冒 雨 赶 
去 上 课 而 感染 了 肺炎 ， 那 一 年 ， 他 年 仅 49 岁 。 
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布尔 于 1854 年 所 发 表 著 作 ， 其 书 名 就 彰显 了 一 种 雄心 壮志 。 因 为 理性 的 人 总 是 通过 
逻辑 去 进行 思考 ， 如 果 我 们 找到 了 一 种 利用 数学 来 描述 逻辑 的 方法 ， 也 会 找到 一 种 用 数 
学 方法 来 描述 大 脑 是 如 何 工作 的 。 妆 然 ， 现 在 这 种 观点 显得 很 是 天 真 〈 然而 在 那个 时 代 
这 确实 是 非常 先进 的 思想 )。 
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布尔 发 明了 一 种 代数 ， 这 种 代数 看 上 去 与 传统 代数 非常 相似 ， 而 且 运算 规则 也 非常 
类 似 。 在 传统 的 代数 中 ， 操 作 数 (通常 为 字母 ) 代表 数字 ， 算 子 〈 通 常 为 “+” 和 “>x”) 
则 用 来 指示 这 些 数字 之 间 如 何 运 算 。 通 常 ， 我 们 应 用 传统 代数 来 解决 可 能 像 这 样 的 问题 : 
安雅 有 3 磅 豆腐 。 贝 蒂 的 豆腐 是 安雅 的 2 倍 。 卡 门 的 豆腐 比 贝蒂 多 5 磅 。 迪 尔 得 丽 的 豆 
腐 是 卡门 的 3 倍 。 试 问 迪 尔 得 丽 有 多 少 豆腐 ? 


在 解决 这 个 问题 时 ,我 们 首先 要 将 文字 叙述 转化 为 数学 语言 ， 下 面 用 四 个 字母 分 别 
表示 每 个 人 所 拥有 的 豆腐 有 多 少 磅 : 


A=3 
B=2x4 
C=B+5 
D=3xC 
将 以 上 4 个 表达 式 带 入 同一 式 子 中 合并 ， 最 终 可 以 得 到 一 个 加 法 和 乘法 混合 运算 的 
式 子 : 


D=3xC 

D=3x(B+5) 

D=3 x((2 x A)+ 5) 

D=3x((2 x 3)+ 5) 

D=33 

当 进行 传统 代数 运算 的 时 候 ， 我 们 会 遵循 一 定 的 规则 。 这 些 规则 在 实际 中 可 能 非常 

根深 蒂 固 ， 以 至 于 我 们 不 再 认为 它们 是 规则 ， 甚 至 可 能 忘记 它们 的 名 字 。 但 规则 确实 是 
任何 形式 数学 运算 的 基础 。 


首先 是 加 法 和 乘法 的 交换 律 (commutative )。 意 思 就 是 , 在 运算 符 两 边 的 操作 数 可 以 
任意 调换 : 


A+B=B+A 
AxB=BxA 


相反 ， 减 法 和 除法 则 是 无 法 应 用 交换 律 的 。 
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加 法 和 乘法 也 遵循 结合 律 (associative )， 如 下 : 


A+(B+C)=(4+B)+C 
4x(BxC=(dxB)xC 


最 后 ， 乘 法 遵循 加 法 分 配 率 (distributive ): 
Ax(B+CO)=(4xB+(4xO) 


传统 代数 的 另 一 个 特点 就 是 ， 它 是 处 理 数 字 的 ， 例 如 ， 豆 腐 的 重量 、 鸭 子 的 数量 、 
火车 行驶 的 距离 或 家 庭 成 员 的 年 龄 。 布 尔 的 天 才 之 处 就 在 于 他 把 代数 从 数 的 概念 中 抽 离 
出 来 而 使 其 更 加 抽象 。 在 布尔 代数 ( Boole’*s algebra， 现 在 也 这 样 叫 ) 中 ， 操 作 数 不 是 数 
字 而 是 类 (class )。 简 单 说 ， 一 个 类 就 是 一 个 事物 的 群体 ， 它 后 来 也 被 称 为 集合 set )。 


以 猫 为 例 。 猫 可 以 分 为 公 猫 与 母 猎 。 为 了 简便 ， 用 字母 到 代表 公 猫 ,字母 刁 代 表 母 
猫 。 记 住 ， 这 两 个 符号 代表 的 不 是 数字 。 公 猫 与 母 猫 的 数量 会 随 着 小 猫 的 出 生 和 老 猫 的 
死去 而 发 生变 化 。 这 两 个 字母 分 别 表示 两 类 猫 一 一 有 特定 特征 的 猫 的 群体 。 当 我 们 提 到 公 
猫 的 时 候 ， 就 可 以 使 用 M。 

我 们 也 可 以 用 别 的 字母 代表 猫 的 颜色 , 例如 : 了 可 以 代表 褐色 的 猫 , B 可 以 代表 黑 猫 ， 
球 代 表白 猫 ，O 代表 不 在 T、B 或 到 集合 中 的 其 他 颜色 的 猫 。 

仍 以 此 为 例 ， 猫 还 可 以 分 为 已 被 绝育 的 和 未 被 绝育 的 。 我 们 用 字母 N 来 表示 已 被 绝 
育 的 猫 ， 字 母 表示 未 被 绝育 的 猫 。 

在 传统 的 (数字 的 ) 代数 中 ， 符 号 “+” 和 “x” 用 来 表示 加 法 和 乘法 。 在 布尔 代数 
中 ， 也 有 “+” 和 “>x” 这 样 的 符号 ， 这 很 可 能 造成 混淆 。 所 有 人 都 知道 在 传统 代数 中 如 
何 将 数字 相 加 或 相 滋 ， 但 是 我 们 如 何 将 类 相 加 或 相 乘 昵 ? 


然而 ,在 布尔 代数 中 ， 并 没有 实际 意义 上 的 加 或 乘 。 而 符号 “+” 和 和 “x” 表示 的 是 
完全 不 同 的 意义 。 


在 布尔 代数 中 ， 符 号 “+” 表 示 两 个 集合 的 并 集 。 两 个 集合 的 并 集 的 意思 就 是 指 第 一 
个 集合 中 的 所 有 元 素 与 第 二 个 类 中 所 有 元 素 的 集合 。 例 如 ，B+tF 表示 的 就 是 所 有 黑 猫 和 
白 猫 的 集合 。 
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在 布尔 代数 中 ， 符 号 “x” 表 示 两 个 集合 的 交集 。 两 个 集合 的 交集 就 是 指 既 在 第 一 个 
集合 中 又 在 第 二 个 集合 中 的 所 有 元 素 的 集合 。 例 如 ，Fx 了 代表 的 是 所 有 神色 母 猫 的 集合 。 
像 传统 代数 一 样 ， 我 们 可 以 将 FxT 写 为 F-T, 或 者 简写 为 FT (布尔 代数 中 的 首选 形式 )。 
可 以 将 两 个 字母 想象 成 两 个 形容 词 昌 联 在 一 起 : 褐色 的 母 猫 。 

为 了 避免 在 传统 代数 与 布尔 代数 间 混 清 ， 有 时 用 符号 “U” 和 “nN” 来 代 苦 “+” 和 
“x”。 布 尔 对 数学 方面 的 革命 性 影响 是 让 人 们 熟知 的 符号 更 加 抽象 ， 因 此 ， 我 决定 坚持 他 
的 做 法 ， 而 不 是 引入 新 的 符号 到 他 的 代数 中 。 


交换 律 、 结 合 律 和 分 配 律 都 在 布尔 代数 中 同样 成 立 。 而 且 在 布尔 代数 中 ， 加 法 还 可 
以 来 分 配 乘法 ， 但 在 传统 的 代数 中 ， 这 是 不 成 立 的 : 


下 TB 有 一 (这 + 及 x( 玉 + 及 


白 猫 和 黑色 母 猫 的 并 集 与 如 下 两 个 集合 的 交集 是 一 样 的， 这 两 个 集合 分 别 是 ， 白 猫 
和 黑 猫 的 并 集 ， 白 猫 和 母 猫 的 并 集 。 昌 然 有 点 难 理解 ， 但 是 ， 这 个 结论 是 成 立 的 。 


布尔 代数 中 还 有 另外 两 个 符号 是 非常 重要 的 。 这 两 个 符号 看 起 来 像 数字 ， 但 是 它们 
并 不 是 真正 意义 上 的 数字 ， 相 对 于 数字 而 言 ， 它 们 有 不 同 的 意义 。 在 布尔 代数 中 , 符号 1 
表示 “全 集 ” 一 一 也 就 是 我 们 所 提 到 的 所 有 事物 。 在 前 面 的 例子 中 , 符号 1 表示 的 就 是 “所 
有 猫 的 集合 ”"。 因 此 : 


M+F=!1 


也 就 是 说 ， 公 猫 与 母 猫 的 并 集 是 所 有 猫 。 同 样 的 ， 宰 色 的 猫 、 黑 猫 、 白 猫 与 其 他 颜色 猫 
的 并 集 也 是 所 有 猫 的 集合 : 


T+B+W+O=!1 
通过 以 下 方法 也 可 以 得 到 所 有 猫 的 集合 ; 
N+U=! 


符号 1 与 减 号 连用 可 以 表示 在 全 集中 排除 一 些 事物 ， 例 如 ， 


lI-M 


意思 就 是 除去 公 猫 的 所 有 猫 的 集合 。 这 个 集合 与 母 猫 的 集合 是 相等 的 : 
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Wo | 
! 
1-M=F 
男 一 个 要 用 到 的 符号 就 是 0, 在 布尔 代数 中 ,符号 0 表示 空 集 一 一 不 包含 任何 元 素 的 


集合 。 空 集 往 往 是 两 个 互 斥 集 合 的 交集 ， 例 如 ， 母 猫 与 公 猫 的 交集 : 
FxM=0 


注意 ,在 布尔 代数 中 ，1 和 0 有 时 也 同 在 传统 代数 中 的 应 用 一 样 。 例 如 ， 所 有 猎 与 母 
猫 的 交集 是 母 猫 的 集合 : 


1xF=F 

空 集 与 母 猫 的 交集 还 是 空 集 : 
0xF=0 

空 集 与 母 猫 的 并 集 则 是 母 猫 ; 
0+F=F 


但 是 有 时 也 会 出 现 与 传统 代数 相悖 的 结果 。 例 如 ， 所 有 猫 与 母 猫 的 并 集 是 所 有 猫 的 
集合 : 


1+F=1 
这 个 式 子 在 传统 代数 中 就 是 没有 意义 的 。 
由 于 下 是 母 猫 的 集合 ,( 1-F) 是 所 有 非 母 猫 的 猫 的 集合 ， 因 此 这 两 个 集合 的 并 外 


7 
库 


F+(1-P=!1 
而 这 两 个 集合 的 交集 为 0: 
Fx (1-P)=0 


在 历史 上 ， 这 个 公式 代表 了 人 逻辑 学 上 的 一 个 重要 概念 : 这 一 概念 被 称 为 矛盾 律 。 了 矛 
盾 律 指出 事物 不 可 能 既是 它 本 身 ， 同 时 又 是 它 的 对 立 面 。 


布尔 代数 中 与 传统 代数 形式 上 最 大 区 别 之 处 就 是 这 样 一 个 表达 式 : 
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FxF=F 


这 个 表达 式 很 明确 地 表达 了 布尔 代数 的 意义 ; 母 猫 和 母 猎 的 交集 依然 是 母 猫 。 但 是 如 果 到 
代表 的 是 数字 ， 这 个 表达 式 就 不 会 成 立 。 布 尔 认为 式 子 : 


及 =XY 


就 是 将 其 代数 同 传统 代数 区 别 开 的 一 条 语句 。 另 一 个 在 传统 代数 中 看 起 来 比较 有 趣 的 式 


路 
舌 Plu 


F+F=F 
母 猫 和 母 猫 的 并 集 依 然 是 母 猫 。 
布尔 代数 提供 了 一 种 解决 亚 里 士 多 德 三 段 论 的 数学 方法 。 我 们 再 看 看 最 著名 的 三 段 
论 法 中 的 前 两 名 ,但 是 现在 不 区 分 性 别 : 
所 有 人 都 难 逃 一 死 ; 
苏 格 拉 底 是 人 。 


我 们 用 了 了 表示 所 有 人 的 集合 ，MM 表示 必 有 一 死 的 事物 ，S 表示 苏 格 拉 底 的 集合 。 


“所 有 人 都 难 逃 一 死 ” 是 什么 意思 ? 意思 就 是 说 所 有 人 的 集合 与 必 有 -一死 的 事物 的 交 
集 是 所 有 人 : 


PxM=P 
命题 Px 路 = MM 是 错误 的 ， 因 为 ， 在 必 有 一 死 的 事物 中 ， 还 包含 猫 、 狗 和 榆树 等 。 


“ 苏 格 拉 底 是 人 ”这 人 句 话 的 意思 就 是 苏 格 拉 底 的 集合 〈 一 个 很 小 的 集合 ) 与 所 有 人 的 
集合 (一 个 很 大 的 集合 ) 的 交集 是 苏 格 拉 底 : 


SxP=S 


根据 第 一 个 等 式 我 们 可 以 得 到 了 = Px M， 我 们 将 这 个 等 式 带 入 到 第 二 个 等 式 中 去 : 


Sx(PxM=S 
根据 结合 律 ， 可 以 写 为 : 
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(SxPxM=S 
并 目 我 们 已 知 $5xP=S， 因 此 上 式 可 以 简化 为 : 


SxM=S 


到 此 ,我 们 得 出 了 结论 。 这 个 表达 式 告诉 我 们 ， 苏 格拉 底 的 集合 与 必 有 一 死 的 事物 
的 集合 的 交集 是 5， 也 就 是 说 ， 苏 格拉 底 必 有 一 死 。 如 果 我 们 让 S$ x M = 0, 会 得 出 苏 格 
拉 底 不 会 死 。 如果 S x M= MN， 结 论 就 会 是 : 只 有 苏 格 拉 底 会 死 ， 其 他 任何 事物 都 是 不 死 
的 ! 


应 用 布尔 代数 证 明 这 个 显而易见 的 事实 《实际 上 在 2400 年 前 苏 格 拉 底 自 己 就 证 明了 
他 必 有 一 死 ) 似乎 有 点 小 题 大 做 ， 然 而 布尔 代数 同样 可 以 用 来 确定 某 种 事物 是 否 遵循 特 
定 的 标准 。 或 许 某 天 你 走 进 了 一 家 宠物 商店 ， 对 店员 说 :“ 我 想 要 一 只 公 猫 ， 已 绝育 的 ， 
白色 或 褐色 都 可 以 ， 或 者 一 只 母 猫 ， 也 要 是 已 绝育 的 ， 除 了 白色 任何 颜色 都 可 以 ; 或 者 ， 
只 要 是 黑 猫 就 可 以 ”店员 会 对 你 说 :“ 你 想 要 的 猫 是 在 以 下 这 样 的 集合 里 ， 


(MxNx(W+DN)+(FxNx(1 -WW+B 

对 么 ? ”你 会 说 :“ 是 的 ! 正 是 !1” 

为 了 确定 店员 是 正确 的 ， 你 大 概 会 去 抛弃 并 集 和 交集 的 概念 , 并 用 OR 和 AND 取 而 
代 之 。 这 里 将 字母 大 写 是 因为 ， 它 们 表示 的 不 仅 是 字面 意义 ， 而 表示 布尔 代数 中 的 运算 。 
做 并 集 的 时 候 ， 可 以 看 做 : 第 一 个 集合 OR 第 二 个 集合 。 做 交集 的 时 候 ， 可 以 看 做 : 第 一 
个 集合 AND 第 二 个 集合 。 除 此 之 外 ，NOT 可 以 看 做 在 1 后 面 加 一 个 减 号 。 总 的 来 说 : 

s 符号 “+”( 之 前 作为 并 集 的 符号 ) 现在 可 以 用 OR 来 表示 。 

s 符号 “x”( 之 前 作为 交集 的 符号 ) 现在 可 以 用 AND 来 表示 。 

。 符号 “1-”( 之 前 意思 是 从 全 集中 去 掉 某 些 元 素 ) 现在 用 NOT 来 表示 。 

因此 ， 原 表达 式 可 以 写 为 : 


(M AND NAND (WOR 四 ) OR (FAND N AND (NOT WW) OR B 


这 样 就 非常 接近 你 所 说 的 话 了 。 注 意 ， 这 里 是 如 何 用 括号 表述 清楚 你 的 意图 的 。 你 
想 要 的 猫 来 自 以 下 三 个 集合 中 的 一 个 : 
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了 
日 


(MAND NAND (W OR 刀 ) 
OR 

(FAND NAND (NOT W)) 
OR 
B 


有 了 这 个 公式 ， 店 员 就 可 以 做 一 个 布尔 测试 了 。 为 了 避免 麻烦 ， 我 采用 了 一 种 略微 
有 点 不 同 的 布尔 代数 形式 一 一 字母 不 仅仅 代表 集合 。 这 里 , 字母 可 以 用 数字 来 赋值 。 我 们 


只 用 数字 0 和 1。 数 字 1 代表 YES，Tme， 即 这 只 猫 是 符合 这 样 的 标准 的 。 数 字 0 表示 
NO，False， 即 这 只 猫 不 符合 这 种 特定 标准 。 


首先 ， 店 员 拿 出 了 一 只 未 绝育 的 褐色 公 猫 。 以 下 是 我 期 望 得 到 的 猫 的 表达 式 : 
(MxNx(W+T)+(FxXNxX(I-W)+B 
以 下 是 用 0 和 1 替换 之 后 的 式 子 : 
(1x0x(0+1))+(0xOx(1 -0)+0 

注意 ， 只 有 A 用 和 7 了 的 值 为 1， 因为 这 只 猫 是 褐色 的 公 猫 。 

现在 我 们 要 做 的 就 是 化 简 这 个 表达 式 。 如果 简化 结果 为 1, 则 这 只 猫 就 符合 你 的 标准 ; 
如 果 简 化 结果 为 0， 那么 这 只 猫 就 不 符合 。 在 化 简 的 时 候 要 切记 , 我们 并 不 是 真 的 在 进行 
加 和 乘 的 运算 ， 尽 管 通常 我 们 可 以 当做 是 。 符 号 “+” 代 表 OR， 符 号 “x” 代 表 AND， 
在 大 多 同类 的 规则 中 适用 ( 有 时 在 现代 课本 中 也 使 用 符号 “和 A” 和 “V” 来 表示 AND 和 
OR， 而 非 用 符号 “x” 和 “+”。 但 是 在 这 里 符号 “+” 和 “x” 是 具有 特殊 意义 的 )。 


当 符 号 “x” 代 表 AND 时 ， 有 以 下 几 种 可 能 的 结果 : 


0x0=0 
Ox1=0 
1x0=0 
1xl=1 


也 就 是 说 ， 只 有 当 运 算 符 AND 左右 两 端 都 为 1 的 时 候 ， 结 果 才 为 1。 这 个 运算 与 常 
规 的 乘法 是 完全 相同 的 ， 该 规则 可 以 总 结 为 如 下 这 样 一 个 表格 ， 这 与 第 8 章 中 加 法 和 乘 


: 


法 表 的 形式 类 似 。 


当 符 号 “+” 表 示 OR 的 时 候 ， 有 以 下 几 种 可 能 的 结果 : 


0+0=0 
0+1=1 
1+0=0 


1+1=1 


如 果 运 算 符 OR 左右 两 端 有 一 个 操作 数 为 1， 则 其 运算 结果 就 为 1。 这 个 运算 与 常规 
的 加 法 类 似 , 但 是 在 1+1= 1 这 里 例外 。 运 算 符 OR 可 以 概括 为 如 下 这 样 一 个 表格 。 


我 们 应 用 这 两 个 表格 来 计算 一 下 原 表 达 式 的 结果 : 
(x0Ox1)+(0x0x1)+0=0+0+0=0 


结果 为 0， 意味 着 NO，False， 这 只 小 猪 不 符合 标准 。 


接着 ， 店 员 拿 出 了 一 只 已 绝育 的 白色 母 猫 。 原 始 表达 式 是 : 


CU4HxNx( 环 +1)+ 下 xxNx( 瑟 )+ 吾 


将 0 和 1 带 入 得 : 


(Ox1x(1+0)+(1x1x(1-1)+0 


(Ox1x1)+(1xIx0)+0=0+0+0=0 
因此 ， 第 二 只 小 猫 也 不 符合 标准 。 
然后 , 店员 拿 出 了 一 只 已 绝育 的 灰色 和 母 猫 ( 灰色 属于 其 他 颜色 一 一 直 EE 
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色 )。 表 达 式 如 下 : 
(Ox 1x(0+0))+(1x1x(1-0)+0 
化 简 结果 为 : 
(Ox1x0)+(lx1x1)+0=0+1+0=1 
最 后 结果 为 1， 意 昧 着 Yes，True， 这 个 只 小 猫 可 以 带 回 家 ( 而且 还 是 只 漂亮 的 小 猫 ! )。 


当晚 ， 在 小 猫 赚 缩 在 你 的 腿 上 睡觉 的 时 候 ， 你 突 发 奇想 是 否 可 以 通过 连通 开关 和 灯 
泡 的 方法 来 确定 某 类 猫 味 是 否 符合 你 的 标准 是 的 ， 你 就 是 个 奇怪 的 孩子 )。 你 根本 没 发 
现 ， 你 将 做 出 一 个 重要 的 概念 上 的 突破 。 你 要 做 的 这 些 实验 将 布尔 代数 与 电路 相 融 合 ， 
并 且 可 以 设计 和 制造 利用 二 进 制 进行 计算 的 计算 机 。 但 是 ， 不 要 让 这 些 吓 倒 你 。 


在 实验 的 开始 ， 将 灯泡 和 电池 正常 连接 起 来 ， 但 是 ， 你 用 了 两 个 开关 ， 而 不 是 一 个 ， 
如 下 图 所 示 。 


像 这 样 一 个 接着 一 个 首尾 相连 的 接线 方式 称 做 串联 ( series )。 如 果 你 闭合 左 端的 开关 ， 
什么 都 不 会 发 生 。 
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关 ， 同 样 什 么 都 不 会 发 生 。 只 有 当 左 


F 关 保持 断 开 ， 而 闭合 右边 的 


如 果 让 左边 的 天 
右 两 个 开关 都 闭合 时 灯泡 才 会 亮 ， 如 下 图 所 示 。 


这 里 的 关键 词 是 “与 ”"。 当 左右 两 个 开关 必须 都 是 闭合 的 时 候 电流 才 流 过 回路 。 


这 个 电路 是 一 个 简单 的 逻辑 演示 。 实 际 上 ， 灯 泡 是 在 回答 “两 个 开关 是 否 都 闭合 ? ， 
这 样 一 个 问题 。 这 个 电路 的 运转 情况 ， 我 们 可 以 总 结 为 如 下 表格 。 
| 左 开关 | 右 开关 | 灯泡 | 
EL 
断 开 | 闭合 | 不 这 
闭合 | 断 开 | 不 之 
办 | 闲人 | 亮 


在 之 前 的 章节 中 ， 我 们 已 经 知道 二 进 制 数 是 如 何 表示 信息 的 一 一 而 信息 是 无 所 不 包 
的 ， 无 论 是 简单 的 数字 还 是 罗 杰 - 艾 伯 特 "拇指 的 方向 都 是 信息 。 我 们 可 以 说 二 进 制 0 代 
表 “ 艾 伯 特 的 拇指 向 下 ”， 二 进 制 1 代表 “ 艾 伯 特 的 拇指 向 上 。” 一 个 开关 有 两 个 状态 ， 
，1 代 


因此 可 以 代表 二 进 制 数 。 我 们 可 以 说 0 代表 “开关 断 开 "，! 代表 “开关 闭合 ”。 一 个 灯泡 
因此 ， 它 也 可 以 用 二 进 制 数 来 表示 。 我 们 可 以 说 0 代表 “灯泡 不 亮 ” 


有 两 种 状态 ， 
表 “ 灯 泡 亮 "。 根 据 以 上 表述 ， 我们 可 以 将 表格 简化 为 如 下 形式 。 
101 用 
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注意 ， 如 果 将 左边 的 开关 和 右边 的 开关 调换 位 置 ， 结 果 是 一 样 的 。 我 们 不 用 分 辨 开 
关 哪 个 是 哪个 。 所 以 ， 上 面 的 表 也 可 以 0 OR 表 类 似 的 形式 。 


的 确 ， 这 与 AND 表 是 一 样 的 


FE 


这 个 简单 的 电路 演示 了 布尔 代数 中 的 AND 运算 。 
接 下 来 ， 稍 微 改变 一 下 开关 连接 方式 ， 如 下 图 所 示 。 
Fe 


这 种 连接 方式 叫做 并 联 ( parallel )。 这 种 连接 与 上 一 种 连接 的 不 同 之 处 就 在 于 ， 闭 合 
上 面 的 开关 ， 灯 泡 就 会 亮 。 
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或 者 闭合 下 面 的 开关 ， 灯泡 也 会 亮 。 


入 证 
会 完 。 


或 者 闭合 所 有 的 天 


| 
| 
\ 


| 

本 
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| 


如 果 上 面 的 开关 闭合 或 者 下 面 的 开关 闭合 或 者 都 闭合 ， 灯 泡 都 会 党 。 这 是 


“或 ” 
Xo 


的 关键 词 为 


电路 又 一 次 做 了 一 个 逻辑 上 的 演示 。 灯 泡 回答 了 “是 否 有 开关 闭合 ? ”的 问题 。 下 


表 总 结 了 这 样 一 个 电路 的 工作 原理 。 


| 上 开关 | 下 开关 | 灯泡 | 


这 


同样 用 0 来 表示 开关 断 开 或 者 灯泡 不 亮 ， 用 1 表示 开关 闭合 或 灯泡 亮 ， 这 个 表 可 以 


写 为 如 下 形式 。 


同样 的 ， 两 个 开关 可 以 调换 ， 因 此 上 表 也 可 以 写 为 如 下 形式 。 


这 就 是 说 ， 两 个 开关 并 联 相当 于 布尔 代数 中 的 OR 运算 。 


最 初 当 你 走 进 宠物 商店 的 时 候 ， 告 诉 店员 :“ 我 想 要 一 只 公 猫 ， 已 绝育 的 ， 白 色 或 宰 


色 都 可 以 ; 或 者 一 只 母 猫 ， 已 绝育 的 ， 除 了 白色 任何 颜色 都 可 以 ; 或 者 一 


会 得 出 以 下 表达 式 ， 
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& 猫 。” 店 员 


10 多 辑 与 开关 一 
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MxNx(W+D)+(FxNx(1 -WW)+B 


既然 你 知道 两 个 开关 串联 表示 还 辑 AND ( 用 符号 “x” 表 示 ); 两 个 开关 并 联 表 示人 逻 
辑 OR ( 用 符号 “+” 表 示 )， 因 此 你 可 以 将 8 个 开关 做 如 下 连接 。 


‘i 
kT 
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此 电路 中 的 每 个 开关 都 用 一 个 字母 来 标记 一 一 与 在 布尔 表达 式 中 所 用 的 字母 一 样 
( 丽 表示 NOT 歼 ， 它 是 1- 形 的 另 一 种 表示 方式 )。 如 果 按 照 从 左 到 右 、 从 上 到 下 的 顺序 
遍历 电路 图 ， 你 就 会 以 同样 次 序 遇 到 出 现在 表达 式 中 的 字母 。 在 表达 式 中 每 个 符号 “x” 
对 应 电路 中 的 两 个 开关 (或 者 两 组 开关 ) 串联 的 点 。 在 表达 式 中 每 个 符号 “+” 对 应 电路 
中 两 个 开关 ( 或 两 组 开关 ) 并 联 的 位 置 。 


与 之 前 一 样 ， 店 员 首 先 拿 出 了 一 只 未 绝育 的 褐色 公 猫 。 闭 合 相应 的 开关 ， 如 下 图 所 


修 o 


尽管 开关 M、 了 和 到 闭合 了 ,但 是 没有 成 功 地 点 亮 灯 泡 。 接 着 ， 店 员 又 拿 出 了 一 只 
已 绝育 的 白色 母 猫 。 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 间 后 的 语言 


| 


ee 


已 绝育 的 灰色 母 猫 。 


这 次 ,灯泡 被 成 功 点 亮 了 ， 表 明 这 只 猫 符合 你 的 全 部 要 求 。 


乔治 布尔 并 没有 连接 这 样 一 个 电路 。 他 没有 兴趣 去 观察 布尔 表达 式 在 开关 、 线 路 
和 灯泡 中 如 何 实现 。 当 然 ， 这 其 中 存在 的 一 个 障碍 就 是 ， 布 尔 死 后 15 年 人 类 才 发 明了 
白炽 灯 。 但 是 塞 缪 尔 : 莫 尔 斯 在 1844 年 论证 了 他 的 电报 机 是 可 行 的 一 一 早 于 布尔 发 表 
《思维 规律 的 研究 》10 年 一 一 将 电报 发 声 器 替换 成 上 述 电路 中 的 灯泡 本 应 该 是 非常 简单 
的 。 


然而 ,在 19 世纪 ,没有 人 将 布尔 代数 中 的 AND 和 OR 同 线路 中 的 开关 串联 及 并 联 
关联 到 一 起 。 没 有 这 样 的 数学 家 ， 没 有 这 样 的 电学 家 ， 没 有 这 样 的 电报 员 ， 没 有 这 样 的 
人 。 甚 至 计算 机 革命 的 偶像 式 和 信物 查尔斯 - 巴 贝 奇 ( 1792-1871 ) 也 没有 ， 他 与 布尔 处 在 
同一 时 代 并 且 了 解 布 尔 的 工作 ， 巴 贝 奇 奋斗 了 一 生 ， 他 最 先 设 计 了 差分 机 Difference 
Engine ) 和 分 析 引 警 (Analytic Engine ), 这 些 在 一 个 世纪 之 后 都 被 看 做 是 现代 计算 机 的 前 
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身 。 本 来 有 些 东 西 可 以 帮 到 巴 贝 奇 的 ， 那 是 什么 呢 ? 我 们 现在 知道 ， 那 就 是 根据 一 台电 
报 器 来 创建 计算 机 ， 而 非 使 用 齿轮 和 杠杆 来 实现 计算 。 


是 的 ， 就 是 电报 器 。 
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在 遥远 的 未 来 ， 关 于 20 世纪 的 早期 计算 机 史 早 已 成 为 人 们 印象 中 模糊 的 记忆 ， 那 时 
很 可 能 有 些 人 会 认为 “logic gates”( 逻辑 门 ) 装置 是 以 著名 的 微软 公司 创始 人 的 名 字 来 命 
名 的 '。 其 实 不 然 。 就 像 我 们 所 看 到 的 一 样 ， 逻 辑 门 与 普通 的 让 水 通过 或 者 让 人 通过 的 门 
是 非常 类 似 的 。 在 逻辑 学 中 ,逻辑 门 的 工作 方式 非常 简单 一 一 让 电流 通过 或 阻止 电流 通过 。 


在 上 一 章 中 ， 你 走 进 了 一 家 宠物 店 ， 并 且说 :“ 我 想 要 一 只 公 猫 ， 已 绝育 的 ， 白 色 或 
褐色 都 可 以 ; 或 者 一 只 母 猫 ， 已 绝育 的 ， 除 了 白色 任何 颜色 都 可 以 ; 或 者 ， 只 要 是 一 只 
黑 猫 就 行 。” 这 人 句 话 被 总 结 为 如 下 布尔 表达 式 .: 


(MxNx(W+D)+(FXNxXQ-W)+B 


同样 也 可 以 用 这 样 一 个 由 开关 和 灯泡 组 成 的 电路 来 表示 ， 如 下 图 所 示 。 


1 Bi Gates 中 的 Gates 在 英文 中 有 “ 门 ”的 意思 一 一 译 者 注 
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这 样 的 电路 有 时 被 称 为 网 络 ( network ), 而 如 今 这 个 词 更 多 地 被 用 来 描述 计算 机 之 间 
的 连接 ， 而 不 仅 指 多 个 开关 的 集合 。 


尽管 这 个 电路 中 的 所 有 元 件 早 在 19 世纪 就 都 已 经 被 发 明 出 来 了 ， 但 在 那个 时 代 , 没 
有 人 意识 到 布尔 表达 式 可 以 在 电路 中 实现 。 这 个 等 价 关 系 直 到 20 世纪 30 年 代 才 被 发 现 。 
主要 贡献 人 是 克 洛 德 。 艾 尔 伍德 。 香 农 ( 生 于 1916 )。1938 年 ， 香 农 在 麻 省 理工 学 院 完 
成 了 那 篇 题 为 《继电器 和 开关 电路 的 符号 分 析 》(4 Symbolic Analysis of Relay and 
Switching Circuits ) 的 著名 硕士 论文 ， 在 文中 阐述 了 这 个 间 题 ( 10 年 之 后 ， 他 又 发 表 了 
论文 “通信 的 数学 原理 ”， 即 The Mathematical Theory of Communication， 这 是 第 一 篇 使 
用 “bit” 这 个 词 来 表示 二 进 制 数字 的 文章 )。 


1938 年 以 前 ， 人 们 已 经 知道 ， 当 两 个 开关 串联 的 时 候 ， 要 同时 闭合 它们 ， 电 流 才能 
通过 ; 当 两 个 开关 并 联 的 时 候 ， 闭 合 其 中 任何 一 个 都 可 以 使 电路 连通 。 但 是 没有 人 像 香 
农 那样 能 清晰 严谨 地 闸 述 :电子 工程 师 可 以 运用 布尔 代数 的 所 有 工具 去 设计 开关 电路 。 
此 外 ,如果 你 简化 了 一 个 描述 网 络 的 布尔 表达 式 ， 那 么 你 也 可 以 简化 相应 的 网 络 。 


例如 ， 你 想 要 的 猫 可 以 用 下 列表 达 式 描述 : 


(MxNx(W+T)+(FxXNx 0-W)+B 


利用 结合 律 , 我 们 可 以 重新 排列 由 AND( x ) 连 接 的 变量 , 并 将 表达 式 写 为 如 下 形式 : 


(NxMx(W+D)+Nx Fx(1-W))+B 


为 了 讲 清楚 这 里 是 如 何 变换 的 ， 我 将 定义 两 个 新 的 符号 , 和 ¥ 和 了 : 
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编码 -一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


X=Mx (W+7D) 
Y=Fx(1-W) 


现在 ,描述 你 想 要 的 小 猫 的 表达 式 可 以 写 为 : 


(NxD+(Nx D+B 
化 简 后 ， 我 们 可 以 将 蕊 和 了 表达 式 代 回 去 。 
注意 ， 变 量 六 在 表达 式 中 出 现 了 两 次 。 利 用 分 配 率 ， 表 达 式 可 以 写 为 只 有 一 个 六 的 
形式 ; 
(NxC+IID+B 
现在 将 蕊 和 了 的 表达 式 带 入 : 


(Nx((Mx(W+D)+(F Xx- WW)+B 


由 于 括号 太 多 ， 这 个 表达 式 看 起 来 并 不 简单 。 但 是 这 个 表达 式 中 少 了 一 个 变量 ,也 
就 意味 着 在 网 络 中 少 了 一 个 开关 。 以 下 就 是 简化 后 的 电路 图 。 


确实 ， 证 明 修改 前 后 的 两 个 电路 功能 等 价 要 比 去 证 明 两 个 表达 式 功 能 相同 简单 许多 。 


事实 上 ， 网 络 中 仍然 有 三 个 开关 是 多 余 的 。 理 论 上 讲 ， 你 只 需要 四 个 开关 来 定义 你 
心目 中 的 猫咪 即 可 。 这 是 为 什么 呢 ? 每 个 开关 都 是 一 个 二 进 制 数 。 你 可 以 设 定 一 个 开关 
代表 猫 的 性 别 ( 开关 断 开 表示 是 公 的 ， 而 闭合 表示 是 母 的 )， 另 一 个 开关 闭合 表示 猫 是 否 
有 生育 能 力 ( 开关 断 开 表 示 未 绝育 ， 而 闭合 则 表示 已 绝育 )。 另 两 个 开关 用 来 表示 猫 的 颜 
色 。 这 里 有 四 种 可 能 出 现 的 颜色 ( 白色、 黑色 、 褐 色 和 其 他 颜色 )， 而 我 们 知道 ， 四 种 选 
择 可 以 用 两 个 二 进 制 位 来 定义 ， 于 是 你 需要 的 就 是 两 个 颜色 开关 。 例 如 ， 两 个 开关 同时 
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: 


断 开 表 示 和 白色 ， 一 个 闭合 表示 黑色 ， 另 一 个 闭合 表示 神色 ， 同时 闭合 表示 其 他 颜色 。 


现在 让 我 们 制作 一 个 用 来 选 猎 咪 的 控制 面板 。 这 个 控制 面板 上 只 有 四 个 开关 ( 与 你 
家 墙 上 控制 灯 开 闭 的 开关 很 相似 )， 此 外 面板 上 还 安装 了 一 个 灯泡 ， 如 下 图 所 示 。 


开关 打 到 上 面 是 指 开关 闭合， 反之 是 指 开关 断 开 。 或 许 用 来 表示 猫咪 颜色 的 两 个 开 
关 标 记 有 点 难于 理解 ， 这 是 为 了 将 面板 做 得 简洁 而 不 得 已 导致 的 一 个 小 缺憾 。 在 表示 颜 
色 的 两 个 开关 中 ,左边 的 叫做 B， 意 思 是 说 只 要 它 闭合 (如 上 图 所 示 ) 就 表示 黑色 。 两 个 
开关 中 右边 的 那个 叫做 T, 意思 是 说 只 要 它 闭合 的 时 候 就 表示 褐色 。 如 果 两 个 开关 都 闭合 
则 表示 其 他 颜色 ， 这 个 选择 叫做 O。 两 个 开关 都 断 开 的 时 候 表示 白色 ,用 W 表示 ， 字 母 
写 在 下 部 。 


在 计算 机 术语 中 ， 开 关 是 一 种 输入 设备 〈input device )， 输 入 是 控制 电路 如 何 工 作 的 
信息 。 在 本 例 中 ， 输 入 开关 对 应 于 4 个 二 进 制 数 信息 ， 这 些 信息 用 来 描述 一 只 猫 。 输 出 
引 设备 (output device ) 就 是 灯泡 。 如 果 开 关 描 述 了 一 只 符合 标准 的 猫 ， 灯 泡 就 会 亮 。 比 如 
上 面 控 制 面板 所 示 的 开关 就 表示 了 一 只 未 绝育 的 黑色 母 猫 。 这 只 猫 符合 你 的 标准 ， 因 此 
- 灯泡 是 亮 的 。 

| 现在 我 们 要 做 的 就 是 设计 一 个 电路 来 控制 这 个 面板 工作 。 


前 面 提 到 ， 香 农 的 论文 题目 是 《继电器 与 开关 电路 的 符号 分 析 》 这 里 的 继电器 与 之 
前 我 们 在 第 6 章 提 到 的 电报 系统 中 的 继电器 很 类 似 。 然 而 在 香农 发 表 论文 的 时 候 ， 继 电 
器 已 经 被 广泛 地 用 于 其 他 领域 ， 特 别 是 在 庞大 的 电话 系统 网 络 中 。 


继电器 像 开 关 一 样 ， 可 以 串联 或 并 联 在 电路 中 执行 简单 的 逻辑 任务 。 这 种 继电器 的 
组 合 叫 做 逻辑 门 〈(logic gates )。 这 里 提 到 的 逻辑 门 执 行 “简单 ”逻辑 任务 是 指 逻 辑 门 只 完 
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一 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
| 


最 基本 的 功能 。 继 电器 优 于 开关 之 处 就 在 于 ， 继 电器 可 以 被 其 他 继电器 所 控制 ， 而 不 
人 工控 制 。 这 就 意味 着 ， 这 些 简单 的 逻辑 门 组 合 起 来 可 以 实现 更 复杂 的 功能 ， 例 如 
一 些 简 单 的 算术 操作 。 事 实 上 ， 下 一 章 中 ， 我 们 就 将 介绍 如 何 利用 电线 、 开 关 、 和 灯泡 、 
电池 和 电报 继电器 来 制作 一 个 加 法 器 ( 尽管 它 只 能 用 于 二 进 制 数 计算 )。 


Bc 过 


前 面 提 到 过 ， 继 电器 对 于 电报 系统 的 工作 而 言 是 至 关 重 要 的 。 在 长 距离 情况 下 ， 连 
接 电报 站 的 电线 具有 很 高 的 电阻 。 这 就 需要 采取 一 些 措施 来 接收 微弱 信号 并 把 它 增 强 后 
再 发 射出 去 。 继 电器 就 是 通过 电 伐 铁 控 制 开关 来 实现 这 一 目的 的 。 实 际 上 ， 继 电器 是 通 
过 放大 微弱 信号 来 生成 强 信号 的 。 


就 我 们 的 目的 而 言 ， 我 们 对 于 继电器 放大 微弱 信号 的 功能 并 不 感 兴趣 。 我 们 真正 感 
兴趣 的 是 继电器 可 以 作为 一 个 电流 控制 而 非 人 工控 制 的 开关 。 我 们 可 以 将 继电器 、 开 关 、 
灯泡 和 两 节 电 池 按 照 下 图 连接 。 


注意 ， 左 边 的 开关 是 断 开 的 ， 灯 泡 没 有 发 光 。 当 闭合 开关 的 时 候 ， 左 端 电 池 产 生 电 
流 流 过 缠 在 铁 芯 上 的 圆 线圈 。 于 是 铁 必 产生 了 磁性 ， 将 上 面 的 弹性 金属 簧 片 拉 下 ， 使 回 
路 接 通 ， 灯 泡 发 光 。 
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当 电 磁铁 将 金属 簧 片 拉 下 来 时 ， 我 们 称 继电器 被 “触发 ”(friggered )。 当 左边 的 开关 
断 开 的 时 候 ， 铁 艺 的 磁性 消失 ， 金 属 簧 户 回 到 原 位 。 


这 看 起 来 似乎 是 一 种 间接 控制 灯泡 发 光 的 方法 ， 而 实际 上 它 就 是 这 样 的 。 如 果 我 们 
上 只 关心 点 亮 开 关 ， 完 全 可 以 将 继电器 省 略 掉 ， 但 我 们 所 关心 的 并 不 仅仅 是 点 亮 灯泡 。 我 
们 还 有 更 宏大 的 目标 。 
在 这 一 章 中 ,( 在 逻辑 门 建 立 之 前 ) 我 们 将 多 次 运用 继电器 ， 因 此 就 需要 将 上 面 那 幅 
路 图 简化 。 我 们 可 以 利用 接地 的 方式 减少 一 些 电 线 。 在 这 种 情况 下 ， 大 地 仅 代表 了 一 
个 公共 端 ， 并 不 是 真正 意义 上 的 物理 接地 。 


这 看 起 来 并 不 像 简化 的 结果 ， 但 到 现在 我 们 还 没有 完成 。 注 意 两 节 电池 的 负极 都 是 
接地 的 。 因 此 ， 我 们 可 以 看 到 这 样 的 符号 。 


和 第 5 章 、 第 6 章 中 一 样 ， 可 以 用 大 写字 母 V (代表 电压 ) 来 代替 上 图 中 的 电池 。 这 
样 ， 继 电器 看 上 去 就 如 下 图 所 示 。 
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开关 闭合 ， 电 流 从 V 端 流出 ， 经 过 电磁 铁 芯 流 到 大 地 上 。 产 生 磁 效 应 吸 合金 属 簧 片 ， 从 
而 连通 了 V、 灯 泡 和 地 之 间 的 电路 ， 使 灯泡 发 光 。 


上 面 的 图 显示 了 两 个 电源 和 两 个 接地 端 。 但 是 在 这 一 章 的 所 有 电路 中 ， 所 有 电源 ， 
即 “V” 是 可 以 彼此 互 连 的 ， 接 地 端 也 如 此 。 在 本 章 和 下 一 章 的 电路 中 ， 所 有 继电器 网 络 
和 逻辑 门 只 需要 一 节 电 池 ， 尽 管 可 能 是 一 节 很 大 容量 的 电池 。 例 如 ， 上 述 电路 图 可 以 画 
为 如 下 只 用 一 节 电 池 的 方式 。 


Mpeg 


项 114 


11 = 


但 是 ， 这 个 电路 图 中 没有 清楚 地 表明 ， 为 什么 我 们 要 使 用 继电器 。 可 以 先 不 看 回路 ， 
单单 看 继电器 ， 像 前 面 的 控制 面板 一 样 ， 从 输出 和 输入 开始 。 


当 电流 流 经 输入 时 《〈 例如， 用 一 个 开关 把 输入 连 到 “V” 端 )， 电 磁铁 就 会 被 触发 ， 输 出 
就 得 到 一 个 电压 。 


继电器 的 输入 不 一 定 只 能 是 开关 ， 其 输出 也 未 必 只 限于 灯泡 。 一 个 继电器 的 输出 可 
以 连 到 男 一 个 继电器 的 输入 ,例如 下 面 这 个 电路 : 


当 开 关闭 合 ， 第 一 个 继电器 被 触发 ， 提 供电 压 给 第 二 个 继电器 。 于 是 第 二 个 继电器 被 触 
发 ， 使 灯泡 发 光 。 
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aa 


连接 继电器 是 建立 逻辑 门 的 关键 。 


实际 上 ， 灯 泡 可 以 采用 两 种 方式 连接 到 继电器 上 。 注 意 ， 弹 性 金属 簧 片 是 被 电磁 铁 
拉 下 来 的 。 平时， 金属 咎 片 与 上 端 触 点 相 接 触 ， 当 电磁 铁 拉 动 它 时 ， 它 就 会 与 下 端 触 点 
相 接触 。 我 们 之 前 一 直 把 金属 簧 片 与 下 方 触 点 接触 作为 继电器 的 输出 ， 而 其 实 也 可 以 把 
它 与 上 方 触 点 相 接触 作为 输出 。 当 我 们 这 样 使 用 的 时 候 ， 继 电器 的 输出 恰好 相反 ， 当 输 
入 开关 断 开 的 时 候 ， 灯 泡 发 光 。 


用 开关 术语 来 说 ， 这 种 继电器 叫做 双 掷 继电器 。 它 拥有 两 个 输出 ， 但 是 这 两 个 输出 
在 电 的 极 性 上 是 对 立 的 一 一 当 一 端 有 电压 时 ， 男 一 端 就 没有 。 
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另外 ， 如 果 想 象 不 出 现代 继电器 是 什么 样子 ， 你 可 以 在 你 们 当地 电器 行 的 简易 透明 


包装 中 看 到 一 些 。 有 些 继电器 就 像 方形 小 冰 块 一 样 大 ,如 零件 型 号 为 275-260 和 275-214 
的 继电器 就 是 这 种 大 小 的 继电器 ， 而 且 它 们 也 十 分 耐用 。 这 些 继电器 内 部 的 元 件 被 封 在 


一 个 干净 的 塑料 外 壳 里 ， 因 此 你 可 以 看 到 电磁 铁 和 金属 簧 片 。 本 章 和 下 一 章 所 描述 的 电 


路 都 使 用 的 是 元 件 号 为 275-240 的 继电器 ， 这 种 继 


而 且 价 格 便宜 〈 每 个 2.99 美 分 )。 


电器 体积 小 《大 约 一 块 口香糖 大 小 ) 


前 面 提 到 ， 两 个 开关 可 以 串联 ， 同 样 地 ， 两 个 继电器 也 可 以 串联 。 


上 面 继电器 的 输出 为 下 面 继电器 提供 电压 。 如 上 图 所 示 


灯泡 不 发 光 。 我 们 先 闭合 上 面 的 开 


‘ 
I 


4 


) 


SE 


， 当 两 个 开关 都 断 开 的 时 候 ， 
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灯泡 仍然 不 亮 ， 因 为 下 面 的 开关 一 直 是 断 开 的 ， 这 个 继电器 没有 被 触发 。 我 们 现在 
断 开 上 面 的 开关 ， 并 闭合 下 面 的 开关 。 


灯泡 仍然 不 亮 。 由 于 上 面 的 继电器 没有 被 触发 ， 电 流 无 法 流 过 灯泡 。 只 有 两 个 开关 
都 闭合 的 时 候 灯 泡 才 会 被 点 亮 。 


这 时 ， 两 个 继电器 都 被 触发 ， 电 流 从 VV 流 经 灯泡 后 流入 到 地 中 。 


就 像 两 个 开关 串联 一 样 ， 这 两 个 继电器 也 执行 了 逻辑 操作 。 只 有 当 两 个 继电器 都 被 
触发 的 时 候 灯 泡 才 会 亮 。 这 样 两 个 继电器 的 串联 被 称 为 一 个 “与 门 ”。 为 了 避免 复杂 的 图 
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示 ， 电 气 工程 师 用 如 下 专门 的 符号 表示 一 个 与 门 。 


A | )— 


这 是 四 个 基本 逻辑 门 中 的 一 个 。 与 门 有 两 个 输入 端 (上 图 中 的 左 端 ) 和 一 个 输出 端 
表示 的 与 门 通常 输入 在 左边 ， 输 出 在 右边 。 这 是 因为 人 们 习惯 于 


(上 图 中 的 右 端 )。 这 林 
由 左 向 右 的 阅读 方式 ， 在 读 电路 图 的 时 候 也 会 由 左 向 右 。 但 与 门 也 可 以 画 成 输入 在 上 端 、 


右 端 或 者 下 端 。 
有 两 个 继电器 、 两 个 开关 和 一 个 灯泡 的 原始 电路 图 如 下 所 示 。 


使 用 “与 门 ”符号 ， 上 图 可 以 画 为 如 下 所 示 的 图 。 


注意 ， 与 门 的 符号 不 仅仅 代替 了 两 个 串联 的 继电器 ， 而 且 还 暗示 着 上 面 的 继电器 与 电源 
相连 ， 两 个 继电器 都 接地 。 只 有 当 上 面 的 开关 与 下 面 的 开关 都 闭合 的 时 候 ， 灯 泡 才 会 发 


光 。 这 就 是 称 它 为 “与 门 ”的 原因 。 
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一 二 编码 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 


与 门 的 输入 未 必 一 定 要 和 开关 相连 ， 而 且 输 出 也 不 一 定 只 能 与 灯泡 相连 。 我 们 真正 
要 处 理 的 是 输入 端的 电压 和 输出 端的 电压 。 例 如 ， 一 个 与 门 的 输出 可 以 作为 另 一 个 与 门 
的 输入 ， 如 下 所 示 。 


只 有 当 三 个 开关 全 部 闭合 的 时 候 ， 灯 泡 才 会 亮 。 只 有 当 上 面 两 个 开关 全 闭合 的 时 候 ， 
第 一 个 与 门 的 输出 才 会 触发 第 二 个 与 门 中 的 第 一 个 继电器 。 而 最 下 面 的 开关 闭合 会 触发 
第 二 个 与 门 中 的 第 二 个 触发 器 


如 果 我 们 将 低 电 平 视 为 0， 将 高 电 平视 为 1， 那么 与 门 的 输入 和 输出 之 间 的 关系 如 下 


所 示 。 
0 1 一 
| 一 一 0 -一 一 和 
0 0 


可 用 下 表 来 描述 。 
AND | 0 1 
0 0 0 
1 0 1 


同样 可 以 计 与 门 有 多 个 输入 端 。 例 如 ， 将 三 个 继电器 串联 ， 如 下 图 所 示 。 
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只 有 当 三 个 开关 全 部 闭合 时 灯泡 才 会 发 光 。 这 个 结构 可 以 用 如 下 符号 来 表示 。 


iri 


RN 


已 被 称 为 三 输入 端 与 门 。 
以 下 逻辑 门 是 由 两 个 继 电 


注意 两 个 继电器 的 输出 是 接 在 一 起 的 ， 这 个 连 在 一 起 的 输出 为 灯泡 提供 了 电源 。 任 
何 一 个 继电器 都 能 点 亮 灯泡 。 例 如 ， 如 果 闵 合 上 面 的 开关 ， 灯 泡 会 亮 。 这 时 ， 灯 泡 从 左 
边 的 继电器 得 到 了 电源 供应 。 
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时 


本 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 


同样 的 ， 如 果 我 们 将 上 面 的 开关 断 开 ， 并 闭合 下 面 的 开关 ， 灯 泡 也 会 发 光 。 
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显而易见 ， 当 上 面 的 开关 或 下 面 的 开关 闭合 , 灯泡 都 会 发 光 , 这 里 的 关键 词 是 “或 ”， 
因此 这 样 的 门 被 称 为 “或 门 "。 电 气 工程 师 用 如 下 符号 表示 或 门 。 


它 和 与 门 的 符号 稍微 有 点 相似 , 但 是 输入 端的 一 边 是 弧 线 , 像 英 文 单词 “OR” 中 字母 “0” 
一 样 (这 样 可 以 帮 你 分 清 它 们 )。 


或 门 的 两 个 输入 中 ， 只 要 有 一 个 加 上 电压 ， 输 出 就 是 高 电 平 。 如 果 将 低 电 平 看 做 0， 
电 平 看 做 1， 那 么 或 门 也 有 四 种 可 能 的 组 合 状态 。 


型 


像 总 结 与 门 一 样 ， 我 们 可 以 将 或 门 的 输入 和 输出 关系 总 结 为 一 个 表 ， 如 下 所 示 。 


或 门 也 可 以 有 多 个 输入 端 ( 只 要 任 一 个 输入 端 为 1， 其 输出 端 就 为 1， 只 有 所 有 的 输 
入 端 都 为 0 时 ， 输 出 端 才 为 0 )。 


前 面 解释 了 为 什么 我 们 所 用 的 继电器 叫 双 掷 继电器 ， 这 是 因为 其 输出 有 两 种 不 同 的 
连接 方式 。 通 常 在 开关 断 开 的 时 候 ， 灯 泡 不 会 亮 。 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


当 开关 闭合 时 ， 灯 泡 发 光 。 
也 可 以 用 另外 一 种 连接 方式 ， 使 开关 断 开 时 灯泡 被 点 亮 。 


这 样 的 话 , 开关 闭合 , 灯泡 就 会 熄灭 。 以 这 种 方式 连接 的 继电器 叫做 反 向 器 ( inverter )。 
反 向 器 不 是 逻辑 门 (一 个 逻辑 门 通 常 有 两 个 或 多 个 输入 ), 尽管 如 此 , 它 的 用 处 还 是 很 广 。 
反 向 器 可 以 用 如 下 的 专门 符号 来 表示 。 
输入 一 一 > 一 一 输出 


由 于 它 能 将 0( 低 电 平 ) 转换 为 1〈 高 电 平 )， 因 此 被 称 为 反 向 器 ， 反 过 来 也 是 一 样 
的 。 
9—| >0—1 
Ts 
利用 反 向 器 、 与 门 和 或 门 ， 我 们 就 可 以 着 手 去 设计 一 个 自动 选择 理想 猫 味 的 控制 面 
板 了 。 首 先 从 开关 开始 ， 第 一 个 开关 闭合 表示 母 猫 ， 断 开 表 示 公 猫 。 因 此 ， 我 们 可 以 得 


到 两 个 信号 ， 把 它们 分 别 叫做 F 和 M， 如 下 图 所 示 。 
VY 


当 F 为 1 时 , M 为 0, 有 反之 亦 然 。 同样 ,第 二 个 开关 闭合 表示 这 只 猫 已 绝育 , 断 开 则 
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表示 这 只 猫 未 绝育 。 


下 面 两 个 开关 更 加 复杂 。 两 个 开关 的 不 同 组 合 分 别 表 示 四 种 不 同 的 颜色 。 以 下 为 两 
个 接 有 电源 的 开关 。 


当 两 个 开关 都 断 开 时 〈 如 上 图 所 示 )， 表 示 和 白色 。 以 下 就 是 如 何 运用 两 个 反 向 器 和 一 
个 与 门 来 得 到 W 信号 的 方式 。 如 果 你 选择 一 只 和 白 猫 ，W 就 为 高 电 平 (1); 否则 ， 就 为 低 
电 平 (0) 


V 
[ee 


当 两 个 开关 断 开 时 ， 两 个 反 向 器 的 输入 均 为 0， 两 个 反 向 器 的 输出 ( 也 就 是 与 门 的 输 
入 ) 都 为 1。 这 就 意味 着 与 门 的 输出 为 1。 如 果 有 一 个 开关 闭合 ， 与 门 的 输出 就 为 0。 


0 可 以 利用 一 个 反 向 器 和 一 个 与 门 实现 
CC 


人 


只 有 当 第 一 个 开关 闭合 而 第 二 个 开关 断 开 的 时 候 ,， 与 门 输出 才 为 1。 同 样 ， 如果 第 二 
个 开关 闭合 而 第 一 个 开关 断 开 ， 与 门 的 输出 也 为 1， 我 们 用 此 来 表示 神色 的 猫 。 
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下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


V 
L_v 一 
HD 
L_ 一 
如 果 两 个 开关 同时 闭合 则 表示 其 他 颜色 的 猫 。 
VY 
a 
¥ 六》 0 
L_ 一 
现在 ,我 们 将 四 个 小 电路 合并 成 一 个 大 电路 ( 按照 惯例 ， 黑 实心 点 表示 交叉 线 之 间 
是 连接 的 ， 没 有 黑 实 心 点 的 交叉 线 则 表示 仅仅 是 穿 过 ， 没 有 连接 )。 


这 个 电路 看 起 来 非常 复杂 ， 但 是 如 果 你 仔细 地 沿 着 线路 走 ， 看 清 每 个 与 门 的 输入 是 
从 哪 来 的 ， 而 暂 不 论 这 些 输 入 去 向 何方 ， 电 路 的 工作 原理 就 会 一 目 了 然 。 如 果 两 个 开关 
都 断 开 ， 输 出 信号 W 就 为 1， 其 他 都 为 0。 如 果 第 一 个 开关 闭合 ， 则 输出 信号 B 为 1, 其 
他 为 0， 依 此 类 推 。 


在 连接 门 和 反 向 器 的 时 候 有 一 些 规则 ， 影响 它们 的 连接 方式 : 一 个 门 (或 反 向 器 ) 


的 输出 可 以 作为 一 个 或 多 个 其 他 门 (或 反 向 器 ) 的 输入 。 但 是 两 个 或 多 个 门 (或 反 向 器 ) 
的 输出 是 不 可 以 相互 连接 的 。 


这 个 由 4 个 与 门 和 2 个 反 向 器 连接 成 的 电路 叫做 “2-4 译 码 器 ”。 输入 为 2 个 二 进 制 
位 ， 各 种 组 合共 表示 4 个 不 同 的 值 。 输 出 是 4 个 信号 ,任何 时 刻 只 能 有 一 个 是 1， 至 于 哪 
一 个 是 1 取决 于 两 个 输入 。 利 用 同样 的 原理 ,我 们 可 以 构造 出 3-8 译 码 器 或 者 4-16 译 码 
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11 门 了 


器 ， 等 等 。 
简化 过 的 选择 猫咪 的 表达 式 为 : 
Nx(MxW+T)+Ex( -WW)+B 


在 这 个 表达 式 中 , 每 个 加 号 (+), 必定 对 应 电路 中 的 一 个 或 门 。 对 于 每 一 个 乘 号 (x )， 
则 对 应 一 个 与 门 ， 电 路 图 如 下 所 示 。 


民 有 攻 己 


电路 图 左 侧 的 字母 由 上 到 下 的 顺序 与 它们 表达 式 中 出 现 的 顺序 一 样 。 这 些 信 和 号 来 源 
于 与 反 向 器 相连 的 开关 和 2-4 译 码 器 的 输出 。 请 注意 用 来 表示 表达 式 中 (1-W ) 部 分 的 反 
向 器 的 用 法 。 


这 时 ， 你 可 能 会 说 :“ 这 一 堆 继电器 太 多 了 !”， 是 的 ， 确 实 如 此 。 每 个 与 门 和 或 门 
中 有 两 个 继电器 , 一 个 反 向 器 中 有 一 个 继电器 。 但 是 我 在 这 里 要 说 的 就 是 你 必须 习惯 它 。 
之 后 的 章节 中 我 们 还 会 用 到 更 多 的 继电器 。 还 好 你 不 用 真 的 买 来 并 在 家 中 自己 连接 它 
们 。 


下 面 要 介绍 另外 两 种 本 章 要 用 到 的 逻辑 门 。 这 两 个 门 都 会 用 到 这 样 一 个 继电器 ， 该 
继电器 在 未 被 触发 时 ， 其 输出 为 高 电 平 《这 是 用 在 反 向 器 中 的 输出 ) 例如 ， 在 下 面 这 种 
配置 中 ， 第 一 个 继电器 的 输出 为 第 二 个 继电器 提供 电源 。 当 两 个 继电器 全 都 断 开 时 ， 灯 
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ea 


如 果 上 面 的 开关 闭合 ， 灯 泡 就 会 熄灭 。 


灯泡 熄灭 是 由 于 第 二 个 继电器 没有 电源 供应 。 同 树 


的 ， 如 果 下 面 的 开关 闭合 


熄灭 。 
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， 灯 泡 也 会 


如 果 两 个 开关 全 部 闭合 ， 灯 泡 也 不 亮 。 


这 些 结果 恰恰 与 或 门 相反 ， 这 个 门 称 为 “或 非 门 ”， 简 称 NOR， 用 以 下 符号 表示 。 
1 一 - 


| } 


除去 输出 部 分 的 小 圆圈 ， 这 个 符号 与 或 门 非常 相像 。 小 圆圈 表示 “ 反 向 ”"”， 所 以 或 非 门 也 


可 用 下 面 的 符号 表示 。 


或 非 门 的 输出 如 下 表 所 示 。 


这 个 表 所 显示 的 结果 与 或 门 正 好 相反 , 在 或 门 中 , 两 个 输入 中 有 一 个 为 1 输出 就 为 1, 只 
有 两 个 输入 都 为 0， 输出 才 为 0。 


下 面 是 另 一 种 连接 两 个 继电器 的 方法 。 
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在 这 种 情况 下 ， 两 个 输出 连接 在 一 起 ， 与 或 门 的 布局 类 似 ， 但 是 却 采用 了 另 一 种 输出 接 
法 。 灯 泡 在 两 个 开关 全 断 开 时 被 点 亮 。 


当 上 面 的 开关 闭合 时 ， 灯 泡 依然 是 亮 的 。 


同样 ， 当 只 有 下 面 的 开关 闭合 时 ， 灯 泡 也 依然 是 亮 的 。 
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: 


只 有 当 两 个 开关 全 闭合 的 时 候 ， 灯 泡 才 会 熄灭 。 


W 


这 一 结果 和 与 门 恰恰 相反 。 这 种 逻辑 门 被 称 为 与 非 门 ， 或 简称 NAND。 与 非 门 的 符 
号 和 与 门类 似 ， 但 在 输出 部 位 多 了 一 个 小 圆圈 ， 意 思 是 输出 和 与 门 正好 相反 。 


ax | )— 输出 


与 非 门 的 输出 如 下 表 所 示 。 
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下 编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 


注意 与 非 门 的 输出 是 和 与 门 完全 相反 的 。 与 门 只 有 当 输 入 全 为 1 的 时 候 输 出 才 为 1, 否则 
输出 就 为 0。 

到 此 为 止 , 我 们 已 经 看 到 可 以 用 四 种 不 同 的 方式 来 连接 有 两 个 输入 、 一 个 输出 的 继 
电器 ， 每 一 种 方式 的 行为 功能 都 不 一 样 。 为 了 避免 重复 画 继电器 ， 我 们 将 它们 称 为 逻辑 


门 ， 并 用 电气 工程 师 们 所 使 用 的 专门 符号 来 表示 它们 。 特 定 收 辑 门 的 输出 取决 于 它 的 输 
入 ， 输 出 与 输入 的 关系 可 总 结 为 以 下 几 个 表格 。 


现在 , 我 们 已 经 有 四 个 逻辑 门 和 一 个 反 向 器 。 把 这 些 工 具 组 合 


到 一 起 其 实 就 是 原始 
的 继电器 ， 如 下 图 所 示 。 


这 叫做 缓冲 器 (buffer )， 可 用 如 下 符号 表示 。 


一 -一 一 


除了 输入 端的 小 贺 圈 ,这 个 符号 与 反 向 器 是 很 相似 的 。 很 明显 , 缓冲 器 “没有 什么 作用 ”， 
它 的 输入 与 输出 是 相同 的 。 
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4 一 一 此 一 一 
1 一 -一 此 一 一 : 
但 是 在 输入 信号 很 微弱 的 时 候 ， 缓 冲 器 就 可 以 派 上 用 场 。 之 前 提 到 过 ， 这 也 就 是 很 
多 年 前 在 电报 机 中 使 用 继电器 的 原因 。 另 外 ， 缓 冲 器 还 可 以 用 于 延迟 一 个 信号 。 这 是 因 
为 继电器 需要 一 点 时 间 一 一 几 分 之 一 秒 一 一 才 会 被 触发 。 


本 书 从 这 里 开始 ， 继 电器 将 会 极 少 出 现 了 。 取 而 代 之 地 ， 以 后 的 电路 会 由 缓冲 器 、 
反 向 器 、 四 种 基本 逻辑 门 和 其 他 由 逻辑 门 组 成 的 复杂 电路 (如 2-4 译 码 器 ) 组 成 。 当 然 ， 
所 有 这 些 器 件 也 是 由 继电器 构成 的 ， 但 我 们 用 不 着 直接 使 用 它 了 。 


前 面 在 建立 2-4 译 码 器 的 时 候 ， 曾 出 现 过 这 样 一 个 小 电路 。 


i 


两 个 输入 信号 经 过 反 向 器 后 作为 与 门 的 输入 。 这 样 的 组 合 有 时 可 以 去 掉 反 向 器 而 画 成 如 


下 的 形式 。 
DD- 


注意 与 门 输入 端的 小 圆圈 。 这 些小 圆 图 表示 信号 在 那 一 点 被 反 转 一 一 将 0( 低 电 平 ) 
转换 为 1 (高 电 平 )， 反 之 亦 然 。 


实际 上 ， 带 有 两 个 反 向 输入 的 与 门 和 或 非 门 是 等 价 的 。 


7)  ) > 


只 有 当 输入 都 为 0 的 时 候 ， 其 输出 才 为 1。 
类 似 的 ， 带 有 两 个 反 向 输入 的 或 门 和 与 非 门 也 是 等 价 的 。 
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ST 编码 一 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
一 一 二 


只 有 当 输 入 全 为 1 时， 输出 才 为 0。 


这 两 组 等 价 关 系 就 是 摩根 定律 在 电路 中 的 实现 。 摩 根 是 维多利亚 女王 时 代 的 另 一 位 
数学 家 , 比 布尔 大 9 岁 , 于 1847 年 发 表 《 形 式 逻 辑 》( Formal Logic ) 一 书 , 与 布尔 的 《 逻 
辑 的 数学 分 析 》( The Mathematical 4nalysis of Logic ) 恰好 同一 天 出 版 (据说 是 同一 天 )。 
实际 上 上 ， 布 尔 研究 逻辑 的 灵感 正 源 于 一 场 公开 的 争论 ， 这 个 争论 就 发 生 在 摩根 和 另 一 个 
被 指 莘 穿 的 英国 数学 家 之 间 〔 历史 最 后 证 实 摩根 是 清白 的 )。 摩 根 很 早 就 发 现 了 布尔 的 洞 
察 力 。 他 无 私 地 鼓励 布尔 ， 并 帮助 他 开展 研究 ， 而 今天 除了 他 的 这 个 著名 定律 之 外 ,他 
几乎 已 被 人 们 所 遗 访 。 


摩根 定律 可 以 简单 地 表示 为 如 下 形式 : 


AxB=A+B 

A+B=AxB 

A 和 B 是 两 个 布尔 操作 数 。 在 第 一 个 表达 式 中 ， 两 个 操作 数 先 被 取 反 ， 再 进行 与 运 

算 。 这 与 两 个 操作 数 进 行 或 运算 后 再 取 反 ( 即 或 非 ) 的 结果 是 一 样 的 。 在 第 二 个 表达 式 
中 ， 两 个 操作 数 先 取 反 ， 再 进行 或 运算 ,这 和 两 个 操作 数 先 做 与 运算 后 再 取 反 ( 即 与 非 ) 
的 结果 是 等 价 的 。 


摩根 定律 是 简化 布尔 表达 式 的 一 种 重要 手段 ， 因 此 也 可 以 用 来 简化 电路 。 从 历史 的 
角度 来 说 ， 这 正 是 香农 的 论文 带 给 电气 工程 师 们 的 真正 意义 。 但 在 本 书 中 简化 电路 不 是 
重点 ， 我 们 关注 的 是 让 一 切 有 效 地 运转 而 不 是 以 最 简 的 形式 运转 。 我 们 下 面 要 做 的 就 是 
一 台 加 法 蜗 。 
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一 进 抽 加 法 器 


| 


加 法 是 算术 运算 中 最 基本 的 运算 ， 因 此 如 果 想 搭建 一 台 计 算 机 ( 这 也 正 是 本 书 所 隐 
念 的 内 容 )， 那 么 首先 就 要 造 出 可 以 计算 两 个 数 的 和 的 器 件 。 当 你 真正 面 对 它 时 ， 就 会 发 
现 ， 原 来 加 法 计算 就 是 计算 机 要 做 的 唯一 工作 。 如 果 我 们 可 以 造 出 加 法 器 ， 同 样 地 ， 就 
可 以 利用 加 法 来 实现 减法 、 乘 法 和 除法 ， 计 算 按揭 付款 ， 引 导 火 箭 飞 到 火星 、 下 棋 ， 以 
及 填写 我 们 的 话费 账单 。 


这 一 章 中 我 们 要 创建 的 加 法 哇 与 现代 的 计算 器 和 计算 机 来 比 ， 将 会 很 庞大 、 很 笨拙 、 
很 慢 ， 而 且 运 转 起 来 噪声 不 断 。 最 有 趣 的 是 我 们 用 来 制作 加 法 器 的 全 部 零件 ， 都 是 像 开 
关 、 灯 泡 、 导 线 、 电 池 、 逻 每 门 、 已 经 预先 连接 在 各 种 逻辑 门 中 的 继电器 等 这 些 在 之 前 
的 章节 中 学 过 的 非常 简单 的 电子 器 件 。 这 个 加 法 器 所 包含 的 所 有 器 件 早 在 120 多 年 前 就 
已 经 被 发 明 出 来 了 。 我 们 并 不 用 在 房间 中 实际 搭建 出 什么 ， 相 有 反 地 ， 可 以 在 纸 上 以 及 我 
们 的 头脑 中 来 搭建 这 个 加 法 器 。 


这 个 加 法 器 完全 用 于 二 进 制 数 的 计算 ， 而 且 没 有 现代 加 法 器 那么 便利 。 你 不 能 使 用 
键盘 来 给 出 需要 相 加 的 两 个 数 ， 相 反 所 要 用 到 的 是 一 排 开 关 。 计 算 结 果 是 通过 一 排 灯 泡 
来 显示 的 ， 而 非 以 数字 的 形式 来 显示 。 


但 是 ， 这 个 加 法 器 确实 可 以 将 两 个 数 相 加 ， 其 方法 与 计算 机 计算 加 法 的 方式 非常 相似 。 


一 下 编码 一 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
一 一 一 


计算 二 进 制 数 加 法 与 计算 十 进 制 数 加 法 非常 相似 。 如 果 你 想 要 让 245 和 673 这 两 个 
十 进 制 数 相 加 ， 你 会 把 这 个 问题 分 解 为 几 个 简单 的 步骤 。 每 个 步骤 只 需要 将 两 个 十 进 制 
数 相 加 。 在 这 个 例子 中 , 首先 要 将 5 和 3 相 加 。 生 活 中 ， 记 住 加 法 表 能 更 快 地 解决 问题 。 


二 进 制 数 加 法 与 十 进 制 数 加 法 最 大 的 不 同 就 在 于 二 进 制 数 加 法 中 用 到 了 一 个 更 为 简 
单 的 加 法 表 。 


如 果 你 是 一 头 鲸 鱼 并 且 在 学 校 中 学 习 了 这 个 表格 ， 你 会 大 声 说 出 : 


0 加 0 等 于 0; 
0 加 1 等 于 1; 
1 加 0 等 于 1; 
1 加 1 等 于 0， 进 位 为 1。 


以 上 加 法 表 可 以 重新 写 为 下 面 带 有 前 导 零 的 形式 ， 这 样 每 个 结果 就 都 是 一 个 2 位 的 
值 。 


像 这 样 ， 一 对 二 进 制 数 相 加 的 结果 中 具有 两 个 数位 ， 其 中 一 位 叫做 加 法 位 ( sum bit )， 另 
一 位 则 叫做 进位 位 ( carry bit， 例 如 ，1 加 1 等 于 0， 进 位 为 1 )。 下 面 我 们 将 二 进 制 数 加 
法 表 分 成 两 个 表格 ， 第 一 个 是 表示 加 法 的 。 


第 二 个 是 表示 进位 的 。 
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12 二 进 制 加 法 器 下 一 
| 


用 这 种 方法 来 看 二 进 制 加 法 非常 方便 ， 因 为 在 我 们 的 加 法 器 中 加 法 与 进位 是 分 别 进 行 的 。 
搭建 一 个 二 进 制 加 法 器 需要 我 们 首先 设计 一 个 电路 ， 通 过 该 电路 执行 这 些 操 作 。 完 全 用 
二 进 制 数 ， 问 题 将 在 很 大 程度 上 得 以 简化 ， 因 为 ， 电 路 中 的 所 有 器 件 ， 像 开关 、 灯 泡 、 
导线 等 都 可 以 用 来 表示 二 进 制 数 的 位 。 


与 十 进 制 数 加 法 一 样 ， 我 们 将 两 个 二 进 制 数字 串 由 右 向 左 依次 逐 列 相 加 。 
01100101 
+ 10110110 
100011011 
注意 ， 在 我 们 将 从 右边 数 的 第 3 列 的 数 相 加 的 时 候 ， 会 有 一 个 1 进位 到 下 一 列 中 。 这 在 
第 6、 第 7、 第 8 列 也 是 一 样 的 。 


想 要 让 多 大 的 二 进 制 数 相 加 ? 由 于 仅仅 在 头脑 中 来 搭建 加 法 器 ， 所 我 们 可 以 搭建 出 
一 个 能 够 让 非常 长 的 二 进 制 数 相 加 的 加 法 器 。 但 是 经 过 理智 的 考虑 之 后 ， 我 们 决定 让 搭 
建 起 来 的 二 进 制 加 法 器 最 高 能 够 执行 的 加 法 长 度 为 8 位 。 也 就 是 说 ， 我 们 想 要 相 加 的 二 
进 制 数 , 其 范围 是 从 0000-0000 到 1111-1111, 即 十 进 制 数 的 0 到 255。 两 个 8 位 二 进 制 的 
和 最 大 可 为 1-1111-1110， 即 510。 


.加 法 器 的 控制 面板 如 下 图 所 示 。 


在 这 个 面板 中 ， 有 两 排 开关 ， 每 排 8 个 。 这 些 开关 就 是 输入 设备 ， 我 们 将 用 它们 来 “ 输 
入 ”两 个 8 位 二 进 制 数 。 在 这 套 输入 设备 中 ， 开 关 断 开 〈 关 ) 即 表 示 0， 闭合 ( 开 ) 表示 
1， 这 与 你 房间 墙 上 的 开关 是 一 样 的。 面板 底部 的 输出 设备 是 一 排 灯泡 ， 共 9 个 。 这 些 灯 
泡 用 来 显示 结果 。 不 发 光 的 灯泡 表示 0， 发 光 的 灯泡 表示 1。 这 里 有 9 个 灯泡 ， 因 为 两 个 


137 如 


8 位 二 进 制 数 的 相 加 结果 可 能 是 一 个 9 位 的 二 进 制 数 。 


加 法 器 的 其 他 部 分 是 以 各 种 形式 连接 起 来 的 逻辑 门 。 开 关 将 触发 逻辑 门 中 的 继电器 
来 点 亮相 应 的 灯泡 。 例 如 ， 如 果 我 们 要 将 0110-0101 和 1011-0110 (之 前 例子 中 的 两 个 数 ) 
相 加 ， 则 要 将 相应 的 开关 置 于 下 图 所 示 位 置 。 


灯泡 发 光 显示 结果 为 : 1-0001-1011( 然而 ， 这 只 是 一 个 希望 的 结果 ， 因 为 我 们 还 没 
有 将 加 法 器 真正 搭建 出 来 ! ) 


在 上 一 章 中 提 到 过 ， 本 书 中 我 们 将 会 用 到 许多 继电器 。 这 个 8 位 二 进 制 加 法 器 中 所 
用 到 的 继电器 不 少 于 144 个 ， 其 中 我 们 用 来 相 加 的 8 对 二 进 制 位 ， 每 对 都 需要 18 个 继 电 
器 。 如 果 将 全 部 电路 展示 出 来 ， 你 一 定 会 崩溃 的 。 没 有 人 能 看 懂 以 各 种 方式 连接 起 来 的 
144 个 继电器 所 表达 的 意义 。 相 反 地 ， 我 们 要 利用 逻辑 门 来 分 阶段 地 处 理 这 个 问题 。 当 看 
到 进位 (两 个 1 相 加 就 会 产生 一 个 进位 ) 结果 表 的 时 候 , 或许 你 已 经 看 出 来 逻辑 门 和 一 
进 制 加 法 的 一 些 相 关 性 了 。 


+ 进位 0 
0 0 0 
1 0 1 


你 可 能 意识 到 了 ， 这 和 上 一 章 中 与 门 的 输出 结果 是 一 样 的 。 


因此 ， 利 用 与 门 可 以 计算 两 个 二 进 制 数 加 法 的 进位 。 
到 此 ， 我们 着 实 取得 了 一 些 进展 。 下 面 我 们 要 做 的 就 是 利用 继电器 来 实现 下 表 。 
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这 是 在 作 两 个 二 进 制 数 加 法 时 需要 解决 的 男 一 个 问题 。 加 法 位 的 情况 并 不 像 进位 位 那样 
简单 ， 但 是 我 们 即将 实现 它 。 


首先 我 们 要 知道 ， 或 门 和 我 们 想 要 的 结果 很 相似 ， 除 了 右 下 角 的 结果 。 


下 面 我 们 将 或 门 和 与 非 门 连接 到 相同 的 输入 上 ， 如 下 图 所 示 。 
输入 A 
输入 B 或 门 输出 


与 非 门 输出 


下 表 总 结 了 或 门 和 与 非 门 的 输出 ， 并 将 其 与 我 们 想 要 的 结果 进行 了 对 比 。 


输入 入 或 门 输出 ”| 与 非 门 输出 | 想 要 的 结果 


注意 , 我 们 想 要 的 是 1， 那么 这 种 情况 只 有 在 或 门 和 与 非 门 的 输出 都 为 1 时 才 会 出 现 。 这 
表明 两 个 输出 端 可 以 通过 一 个 与 门 连接 到 一 起 。 
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一 十 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 
| 


这 就 是 我 们 想 要 的 结果 。 ; 

注意 ， 在 整个 电路 中 仍然 有 两 个 输入 和 一 个 输出 。 两 个 输入 同时 作为 或 门 和 与 非 门 
的 输入 。 或 门 和 与 非 门 的 输出 又 分 别 作 为 一 个 与 门 的 输入 ， 最 后 得 出 了 我 们 想 要 的 结果 。 
GT 
0 
二 
i 

实际 上 这 个 电路 有 个 专门 的 名 称 ， 叫 做 异 或 门 ， 简 写 为 XOR。 之 所 以 称 为 异 或 门 是 
因为 车 想 其 输出 结果 为 1， 要么 仪 让 输入 A 为 1， 要 么 仪 让 输入 B 为 1， 两 输入 端 都 为 1 


则 输出 为 0。 为 了 不 把 或 门 、 与 非 门 和 与 门 都 画 出 来 , 我 们 可 以 使 用 一 个 电气 工程 师 所 采 
用 的 特定 电气 符号 来 表示 异 或 门 。 


异 或 门 在 输入 端 比 或 门 多 出 了 一 条 曲线 ， 除 此 之 外 它 看 上 去 和 或 门 非常 相像 。 异 或 门 的 
特征 如 下 表 所 示 。 


| 
异 或 门 是 本 书 中 详细 介绍 的 最 后 一 个 逻辑 门 (第 6 个 门 有 时 会 在 电气 工程 中 介绍 到 。 它 
称 做 同 或 门 ， 因为 只 有 当 两 个 输入 相同 的 时 候 ， 其 输出 才 为 1。 同 或 门 所 给 出 的 输出 刚好 
与 异 或 门 相反 ， 因 此 同 或 门 的 符号 和 异 或 门 相同 ,但 在 输出 端 多 了 个 小 贺 圈 )。 
让 我 们 回顾 一 下 到 目前 为 止 所 了 解 的 内 容 。 将 两 个 二 进 制 数 相 加 将 产生 一 个 加 法 位 
和 一 个 进位 位 。 
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两 个 二 进 制 数 相 加 的 结果 是 由 异 或 门 的 输出 给 出 的 ， 而 进位 位 是 由 与 门 的 输出 给 出 的 。 
因此 我 们 可 以 将 与 门 和 异 或 门 连 在 一 起 来 计算 两 个 二 进 制 数 ( 即 A 和 B) 的 和 。 


输入 A 
输入 也 


加 和 输出 


进位 输出 


为 了 避免 重复 夯 与 门 和 异 或 门 ， 你 可 以 采用 如 下 这 种 简单 的 表示 方式 。 


输入 A 让 5 加 和 输出 
半 加 器 
输入 B 中 CO 进位 输出 


这 个 符号 被 称 为 半 加 器 (HalfAdder )。 之 所 以 叫 半 加 器 是 有 原因 的 , 它 将 两 个 二 进 制 数 相 
加 ， 得 出 一 个 加 法 位 和 一 个 进位 位 。 但 是 绝 大 多 数 二 进 制 数 是 多 于 1 位 的 。 半 加 器 没有 
做 到 的 是 将 之 前 一 次 的 加 法 可 能 产生 的 进位 位 纳入 下 一 次 运算 。 例 如 ， 假 设 我 们 要 将 如 
下 两 个 二 进 制 数 相 加 。 
11311 

十 生生 生生 

和 44144 合 
我 们 只 能 将 半 加 器 用 于 最 右面 一 列 的 相 加 : 1 加 1 等 于 0， 进位 1。 对 于 从 右面 算 起 的 第 
二 列 ， 由 于 进位 位 的 存在 ， 实 际 上 需要 将 三 个 二 进 制 数 相 加 ， 而 随后 每 一 列 的 加 法 都 是 
这 样 的 。 随 后 的 每 一 列 二 进 制 数 相 加 都 需要 将 进位 位 算 进 来 。 
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下 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


为 了 对 三 个 二 进 制 数 进行 加 法 运算 ， 我 们 需要 将 两 个 半 加 器 和 一 个 或 门 做 如 下 连接 。 


要 理解 它 的 工作 原理 ， 首 先 从 最 左边 第 一 个 半 加 器 的 输入 A 和 输入 B 开始 ， 其 输出 是 一 
个 加 和 及 相应 的 进位 。 这 个 和 必须 与 前 一 列 的 进位 输入 相 加 ， 然 后 再 把 它们 输入 到 第 二 
个 半 加 器 中 。 第 二 个 半 加 器 的 输出 和 是 最 后 的 结果 。 两 个 半 加 器 的 进位 输出 又 被 输入 到 
一 个 或 门 中 。 你 可 能 会 觉得 ， 这 里 还 需要 一 个 半 加 法 器 ， 这 当然 是 可 行 的 。 但 是 如 果 你 
了 解 了 所 有 的 可 能 性 之 后 ， 你 会 发 现 ， 两 个 半 加 法 器 的 进位 输出 是 不 会 同时 为 1 的 。 或 
门 在 这 里 已 经 足够 ， 因 为 或 门 除 了 在 输入 都 为 1 的 时 候 以 外 ， 其 他 情况 下 结果 和 异 或 门 
结果 相同 。 


为 了 避免 重复 地 画 上 面 的 那个 图 ， 我 们 用 以 下 形式 来 替代 上 图 中 的 一 扒 符 号 ， 它 称 
为 全 加 器 (Full Adder )。 


进位 输入 
加 和 输出 

输入 六 
进位 输出 

输入 BB 


输入 B 
EE ER 
BE | 0 | 
0 
mE 
eG 
EE 
| 


在 本 章 前 面 曾经 提 到 过 ,我 们 的 加 法 器 需要 144 个 继电器 。 下 面 就 来 解释 一 下 这 个 数目 
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12 2 


是 如 何 得 到 的 。 每 个 与 门 、 或 门 和 与 非 门 都 需要 两 个 继电器 ， 因 此 一 个 异 或 门 中 就 包含 

个 继电器 。 一 个 半 加 器 是 由 一 个 异 或 门 和 一 个 与 门 组 成 的 ， 因 此 一 个 半 加 器 就 需要 8 个 
继电器 。 每 个 全 加 器 由 两 个 半 加 器 和 一 个 或 门 组 成 ， 所 以 它 要 18 个 继电器 。 我 们 需要 8 
个 全 加 器 来 制作 8 位 二 进 制 加 法 器 。 因 而 总 共 需 要 144 个 继电器 。 


再 来 看 看 之 前 提 到 的 由 灯泡 和 开关 所 组 成 的 控制 面板 。 现 在 我 们 可 以 开始 将 开关 和 
灯泡 连接 到 全 加 器 了 。 


当 把 两 个 二 进 制 数 相 加 时 ， 第 1 列 的 处 理 方式 与 其 他 列 有 所 不 同 。 因 为 后 面 的 几 列 可 能 
包括 来 自前 面 加 法 的 进位 ， 而 第 1 列 不 会 ， 所 以 全 加 器 的 进位 输入 端 是 接地 的 ， 这 表示 
第 1 列 的 进位 输入 是 一 个 0。 第 1 列 二 进 制 数 相 加 后 很 可 能 会 产生 一 个 进位 输出 , 这 个 进 
位 输出 是 下 一 列 加 法 的 输入 。 


对 于 接 下 来 的 两 个 二 进 制 位 和 灯泡 ， 可 以 按 如 下 办 法 来 连接 全 加 器 。 
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a 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


进位 输出 


第 一 个 全 加 器 的 进位 输出 就 是 第 二 个 全 加 器 的 进位 输入 。 随 


的 方式 连接 。 每 一 列 进位 输出 都 是 下 一 列 的 进位 输入 。 


这 里 ， 最 后 一 个 进位 输出 将 被 连接 到 第 9 个 灯泡 上 。 
至 此 ,我 们 就 大 功 告 成 了 。 


还 可 以 用 男 一 种 方式 来 看 这 8 个 全 加 器 的 连接 ， 每 个 全 加 器 的 进位 输出 都 作为 下 一 
个 全 加 器 的 进位 输入 。 


进位 输出 8 位 和 


下 面 是 画 成 一 个 盒子 的 完整 的 8 位 二 进 制 加 法 器 , 输入 标记 为 Ao~ A; 和 Bo~ B， 输 出 标 
记 为 So~ Sr。 
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12 ”二进制 加 法 器 i 
一 | 


人 


8 位 吉 法 露 
Sedy 


和 
进位 输出 输出 和 


这 就 是 表示 多 位 数字 中 各 位 数字 的 常用 方法 。Ao、Bo 和 So 是 最 低 有 效 位 ， 或 者 说 是 最 右 
边 的 一 位 。Ar、B7y 和 S7 是 最 高 有 效 位 ， 或 者 说 是 最 左边 的 一 位 。 例 如 ， 下 面 演 示 了 这 样 
一 列 带 有 下 标的 字母 是 如 何 用 来 表示 一 个 二 进 制 数 0110-1001 的 。 
A, A A AAA A A, 
0 1 1 0 1 0 0 1 
下 标 从 0 开始 ， 并 且 向 着 高 有 效 位 的 方向 递增 ， 因 为 它们 和 2 的 乘 方 数 〈 窒 ) 相对 
应 。 


0 
OO118041001 


如 果 把 下 面 一 排 的 每 个 二 进 制 位 和 其 对 应 的 2 的 寡 相 乘 再 依次 相 加 ， 你 就 会 得 到 
0110-1001 的 十 进 制 数 表示 64+32+8+1， 即 105。 


另 一 种 8 位 二 进 制 加 法 器 可 用 下 图 表示 。 
输入 A 。 输入 B 


人 -人 Au B- B, 


CO ”8 位 加 法 嚣 。CI 
Sr .3g 


进位 输出 


双 线 箭头 包含 了 8 个 输入 端 ,代表 一 组 8 个 独立 的 信号 。 它 们 被 标识 为 A7...Ao、B7...Bo、 
SSo， 同 样 也 表示 一 个 8 位 二 进 制 数 。 


一 且 你 搭建 起 了 8 位 二 进 制 加 法 器 ， 你 就 可 以 再 搭建 男 外 一 个 加 法 器 。 把 它们 级 联 
起 来 就 可 以 很 容易 地 扩展 出 一 个 16 位 加 法 器 。 


145 如 


下 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


A 输入 A 输入 B 
(高 8 位 ) (高 8 位 }) ( 括 8 位 ) ”《 低 8 位 ) 
| 上 


is! 8 


进位 输出 


. 16 和 位 和 
右边 加 法 器 的 进位 输出 被 连接 到 了 左边 加 法 器 的 进位 输入 上 。 左 边 加 法 器 的 输入 包含 了 
两 个 加 数 的 高 8 位 ， 而 得 到 的 结果 也 是 最 终 加 和 的 高 8 位 。 


你 可 能 会 问 :“ 这 真 的 就 是 计算 机 进行 加 法 运算 时 所 采用 的 方式 么 ? ” 
基本 上 来 说 ， 是 的 。 但 也 并 不 完全 是 。 


首先 ， 可 以 制作 一 个 比 这 个 算得 更 快 的 加 法 器 。 如 果 你 看 一 下 这 个 电路 是 如 何 工作 
的 ， 最 低 有 效 位 的 一 对 数字 相 加 所 得 出 的 一 个 进位 输出 ， 将 要 参与 接 下 来 的 一 对 数字 的 
加 法 运算 ， 由 此 得 到 的 一 个 进位 输出 又 要 参与 再 下 一 对 数字 的 加 法 运算 ， 依 此 类 推 。 加 
法 器 的 总 体 速度 等 于 数字 的 位 数 乘 以 全 加 器 器 件 的 速度 , 这 被 称 做 行 波 进位 (ripple carry， 
或 脉冲 进位 )。 更 快 的 加 法 器 运用 了 一 个 被 称 为 “前 置 进 位 ”的 电路 来 提高 运算 的 速度 。 


其 次 ， 也 是 最 重要 的 ， 计 算 机 已 经 不 再 使 用 继电器 了 ! 尽管 它 曾经 被 使 用 过 。 第 一 
台数 字 计 算 机 在 20 世纪 30 年 代 被 建造 完成 ， 当 时 所 使 用 的 就 是 继电器 ， 后 来 也 使 用 过 
真空 管 。 今 天 的 计算 机 使 用 的 是 晶体 管 。 在 被 用 到 计算 机 中 时 ， 晶 体 管 的 工作 方式 与 继 
电器 基本 相同 ， 但 是 正如 我 们 即将 了 解 到 的 ， 晶 体 管 要 比 继电器 计算 速度 更 快 、 体 积 更 
小 ， 而 且 噪 声 更 弱 、 耗 能 也 更 低 ， 而 且 更 便宜 。 拱 建 一 个 8 位 加 法 器 依然 需要 144 个 晶 
体 管 《如 果 你 用 前 置 进位 法 代替 行 波 进位 ， 将 会 用 到 更 多 的 晶体 管 )， 但 是 电路 却 是 极 小 
的 。 
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如 何 实现 减法 


当 你 确信 继电器 连接 到 一 起 真 的 可 以 实现 二 进 制 数 加 法 的 时 候 ， 你 可 能 会 问 :“ 那 么 
如 何 实现 减法 呢 ? ”本 章 后 续 的 内 容 会 帮 你 解答 这 个 问题 ， 因此 提出 这 样 的 问题 并 不 是 
说 你 在 没事 找事 ， 而 实际 上 这 表明 你 是 相当 有 察觉 力 的 。 加 法 和 减法 在 某 些 方面 相互 补 
充 ， 但 在 机 制 方面 这 两 个 运算 则 是 不 同 的 。 加 法 是 始终 从 两 个 加 数 的 最 右 列 向 最 左 列 进 
行 计算 的 。 每 一 列 的 进位 加 到 下 一 列 中 。 在 减法 中 没有 进位 ， 而 是 有 借 位 种 与 加 法 
存在 本 质 区 别 的 麻烦 机 制 。 


例如 ， 我 们 来 看 一 个 典型 的 借 位 减法 的 题目 : 
253 


一 176 
233 


要 解决 这 个 问题 ， 首 先 从 最 右 列 着 手 。 我 们 看 到 ，6 是 大 于 3 的 ， 因 此 从 5 上 借 1， 
再 用 13 减 去 6， 得 到 结果 为 7。 由 于 我 们 已 经 在 5 上 借 了 1, 因此 ， 现 在 实际 上 那 一 位 是 
4， 而 4 是 小 于 7 的， 因此 继续 从 2 上 借 1，14 减 7 结果 为 7。 而 由 于 在 2 上 借 了 1， 实 
际 上 这 一 位 是 1， 从 中 减 去 1， 结 果 为 0。 因 此， 最 后 的 结果 应 为 77: 


ee 后 的 语言 


如 何 才能 通过 一 连 串 逻辑 门 来 实现 这 个 反 逻 辑 呢 ? 


然而 , 我们 并 不 打算 这 样 做 。 相 反 ， 我 们 打算 用 一 个 小 技巧 来 让 减法 不 涉及 借 位 。 
这 会 使 波 洛 尼 厄 斯 '( 既 不 是 欠 债 人 也 不 是 出 借 人 ) 满意 ,我 们 其 他 人 也 一 样 。 此 外 ， 由 
于 减法 与 计算 机 中 以 二 进 制 编码 的 存储 有 关 ， 详 细 地 了 解 减法 也 是 很 重要 的 。 
为 了 便于 表达 ， 将 进行 减法 的 两 个 数 分 别 用 被 减 数 ( minuend ) 和 减 数 ( subtrahend ) 
表示 。 从 被 减 数 中 减 去 减 数 ， 得 到 的 结果 叫做 差 (difference )。 
被 减 数 
一 减 数 
2 
为 了 避免 借 位 ， 首 先 要 从 999 中 减 去 减 数 ， 而 不 是 从 原来 的 被 减 数 中 减 去 减 数 。 


999 
一 78 
823 


于 操作 数 是 三 位 数 ， 所 以 这 里 使 用 999。 如 果 操 作 数 是 4 位 ， 则 用 9999。 从 一 串 9 
中 减 去 一 个 数 叫 做 对 9 求 补 数 。176 对 9 的 补 数 是 823。 反之 亦 然 : 823 对 9 的 补 数 是 176。 
这 样 的 好 处 就 是 无 论 减 数 是 多 少 ， 计 算 对 9 的 补 数 都 不 需要 借 位 。 


计算 出 减 数 对 9 的 补 数 后 ， 将 补 数 与 原来 的 被 减 数 相 加 : 


1 波 洛 尼 尼 斯 是 莎士比亚 著名 戏剧 《 哈 姆 莱 特 》 中 的 一 位 世故 的 御前 大 臣 ， 他 在 第 一 幕 第 三 
场 向 他 即将 离 家 外 出 的 儿子 说 了 一 大 段 告诫 的 话 ， 其 中 有 一 句 : “不 要 向 人 告 贷 ， 也 不 要 
借 钱 给 人 。 因 为 向 人 告 贷 的 结果 ， 容 易 养 成 因 循 懒惰 的 习惯 ; 而 把 债 款 放 了 出 去 ， 往 往 不 
但 丢 了 本 钱 , 而 且 还 失去 了 朋友 。” 后 来 ,美国 经 济 学 家 范 里 安 在 其 所 著 的 《微观 经 济 学 : 
现代 观点 》 一 书 中 使 用 了 “ 波 洛 尼 厄 斯 ”一 词 ， 该 词 就 成 为 了 经 济 学 中 的 一 个 概念 。 经 济 
学 在 研究 消费 者 进行 跨 时 期 的 消费 行为 时 ， 把 这 种 既 不 向 别人 借 钱 、 也 不 借 钱 给 别人 的 状 
访 叫 作 “ 波 洛 尼 厄 斯 点 ”。 因 此 ， 这 里 的 “ 波 洛 尼 厄 斯 ”也 就 表示 既 不 向 别人 借 钱 、 也 不 
省 钱 给 别人 的 人 。- 一 译 者 注 
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13 ”如 何 实现 减法 下 一 


a | 
! 


253 
才 如 23 
414075 


最 后 再 将 结果 加 1， 并 减 去 1000。 


1076 
二 各 
一 0D 


Ee 


到 此 ， 我 们 束 得 到 了 结果 。 答 案 与 先前 的 相同 ， 而 且 没 有 用 到 借 位 。 


为 什么 这 种 方法 行 得 通 呢 ? 原 题 目 是 这 样 的 : 


233 — 176 


在 这 个 式 子 中 加 上 一 个 数 再 减 去 这 个 数 ， 结 果 是 相同 的 。 因 此 先 加 上 1000， 再 减 去 
1000: 


253 - 176 + 1000- 1000 
这 个 式 子 与 下 式 等 价 : 


253 一 176+999+1-1000 


然后 用 以 下 方式 将 数字 重新 组 合 : 
253 + (999 — 176)+1—1000 
这 个 式 子 与 刚才 描述 过 的 用 9 的 补 数 进行 的 计算 是 相同 的 。 我 们 用 两 个 减法 和 两 个 
加 法 来 替代 一 个 减法 ， 而 在 这 个 过 程 中 避免 了 烦琐 的 借 位 。 
如 果 减 数 大 于 被 减 数 会 怎么 样 呢 ? 例如 以 下 问题 


47 和 
一 253 
了 


in 


通常 遇 到 这 个 问题 时 你 可 能 会 说 :“ 这 里 减 数 大 于 被 减 数 ， 因 此 要 将 减 数 和 被 减 数 交 
换 来 执行 减法 ， 然 后 给 结果 取 个 相反 数 。” 你 可 能 在 脑子 里 将 这 两 个 数 交 换 ， 而 写 出 这 样 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 


的 答案 : 


1768 
一 253 
7Z7Z 


如 果 希 望 求 解 这 个 问题 而 不 使 用 借 位 的 话 ， 就 要 采用 与 之 前 稍微 不 同 的 方法 。 首 先 
要 像 前 面 一 样 ， 用 999 减 去 减 数 233， 计 算出 对 9 的 补 数 : 


999 
一 253 
746 


把 该 数 对 9 的 补 数 与 被 减 数 相 加 : 


1476 
十 74 如 
922 


在 前 面 的 例子 中 ， 下 一 步 应 该 加 1， 并 减 去 1000 来 得 到 最 终结 果 。 但 是 在 这 里 ， 这 
种 方法 并 不 适用 。 因 为 你 会 遇 到 923 减 去 1000 的 情况 ， 这 又 导致 了 借 位 。 


由 于 我 们 之 前 已 经 加 了 999， 这 里 再 减 去 999: 


922 
一 999 
了 ?2 


到 这 里 ， 我 们 会 意识 到 这 个 问题 的 结果 是 负数 ， 因 此 需要 将 减 数 与 被 减 数 交 换 ， 用 
999 减 去 922。 这 里 没有 用 到 借 位 ， 结 果 与 我 们 期 望 的 相同 


922 
一 999 
一 77 


同样 的 技巧 可 以 用 于 二 进 制 数 中 ， 而 且 实际 上 这 要 比 十 进 制 数 简单 。 让 我 们 一 起 来 
看 看 该 如 何 操作 。 


原来 的 减法 题目 是 : 


hh 150 
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| 
253 


一 47 各 
2327 


将 这 些 数字 转化 为 二 进 制 数 ， 问 题 变 为 : 


全 二 省 于 全 生生 用 
一 T10000 
2297779? 


第 一 步 ， 用 11111111( 即 255 ) 减 去 减 数 ， 
下 和 生生 村 中 


— 10110000 
D410O04144 


当 计 算 十 进 制 数 碱 法 的 时 候 ， 减 数 是 从 一 申 9 中 减 去 的 ， 结 果 称 为 9 的 补 数 。 在 二 
进 制 数 减法 中 ， 减 数 是 从 一 串 1 中 减 去 的 ， 结 果 称 为 1 的 补 数 。 但 是 请 注意 ， 我 们 在 求 
对 1 的 补 数 时 并 不 需要 用 到 减法 。 在 求 对 1 的 补 数 时 ， 只 需 将 原来 的 二 进 制 数 中 的 1 变 
为 0, 将 0 变 为 ! 即 可 。 因此 对 1 求 补 数 有 时 也 会 称 为 相反 数 (negation ) 或 反 码 ( inverse )。 
这 里 你 可 能 会 想起 第 11 章 中 的 反 向 器 ， 它 的 作用 就 是 将 0 变 为 1, 将 1 变 为 0。 

第 二 步 ， 将 减 数 对 1 的 补 数 与 被 减 数 相 加 : 


生生 是 下 全 于 他 各 
+4 O001144 
101001100 


第 三 步 ， 将 上 式 所 得 结果 加 1: 


101004100 
| 
30100343401 


第 四 步 ， 减 去 100000000( 即 256 ): 
10t10041101 
- 100000000 
4004101 


结果 就 等 于 十 进 制 数 的 77。 
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我 们 把 这 两 个 数 颠 倒 位 置 后 再 做 一 遍 。 在 十 进 制 中 ， 减 法 题目 对 应 于 : 


而 用 二 进 制 表示 为 : 


14104110000 
一 1434144403 


第 一 步 . 用 11111111 减 去 减 数 ， 得 到 对 1 的 补 数 : 


和 1 和 生生 14 
一 和 41444 人 3 
O0000010 


第 二 步 ， 将 减 数 对 1 的 补 数 与 被 减 数 相 加 : 


140110000 
+ O0000010 
10110010 


现在 我 们 要 用 某 种 方法 在 结果 中 减 去 11111111。 当 减 数 小 于 被 减 数 的 时 候 , 我 们 将 结 


果 加 1 再 减 100000000 来 完成 计算 。 但 是 你 无 法 在 不 借 位 的 情况 下 做 到 这 一 点 。 所 以 ， 


我 们 先 用 11111111 减 去 所 得 结果 : 


二 人 和 全 4 和 和 
— 10110010 
O1001101 


这 里 又 一 次 用 到 了 将 各 位 取 反 来 求 得 结果 的 方法 ， 但 是 这 个 结果 是 77， 而 真正 的 答 


案 应 该 是 -77。 


到 这 里 ， 我 们 已 经 有 了 足够 的 条 件 来 改造 上 一 章 所 搭建 的 加 法 器 ， 并 让 它 像 实现 加 


法 一 样 来 实现 减法 运算 。 为 了 不 让 问题 太 复杂 ， 这 个 新 的 加 /减法 器 
减 数 的 减法 操作 ， 即 结果 为 正 数 的 操作 。 


该 加 法 器 的 核心 是 由 逻辑 门 集成 的 8 位 全 加 器 。 
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只 执行 在 减 数 小 于 被 
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输入 A 输入 日 进位 输入 


一 [~ 


Eo 


CO 3 位 加 法 器 
9 Sp 


进位 输出 输出 和 


你 可 能 还 记得 , 输入 Ao~ Ar 及 Bo~ B? 与 两 排 分 别 表 示 两 个 要 相 加 的 8 位 二 进 制 数 的 
开关 相连 。 进 位 输入 接地 。So~ S? 与 表示 结果 的 8 个 灯泡 相连 。 由 于 这 个 加 法 有 可 能 得 到 
9 位 数值 ， 进 位 输出 端 也 连接 了 一 个 灯泡 。 


控制 面板 示意 如 下 图 所 示 。 


在 上 图 中 ， 开 关 所 表示 的 是 183 ( 即 10110111 ) 与 22( 即 00010110 ) 相 加 ， 结 果 如 
灯泡 所 示 为 205 ( 即 11001101 )。 

8 位 加 /减法 器 所 用 的 新 面板 较 从 前 做 了 些许 的 改动 。 它 增设 了 一 个 开关 ， 用 以 选择 
做 加 法 还 是 做 减法 。 


153 总 


” 如 上 图 所 示 ， 这 个 开关 向 下 断 开 时 表示 选择 加 法 运算 ，, 反之 向 上 接 通 则 表示 选择 减 
法 运算 。 此 外 , 右 侧 的 8 个 灯泡 用 于 表示 计算 结果 。 这里, 第 9 个 灯泡 表示 “上 溢 / 下 溢 "。 
这 个 灯泡 表明 了 正在 计算 的 数字 是 一 个 不 能 用 8 个 灯泡 来 表示 的 数字 。 如 果 在 加 法 中 得 
到 了 大 于 255 (上 溢 ，overflow ) 或 在 减法 中 得 到 了 负数 (下 溢 ，underflow ) 这 个 灯泡 就 
会 发 江 。 当 减 数 大 于 被 减 数 的 时 候 ， 就 会 得 到 一 个 负数 。 


加 法 器 中 新 增 的 主要 部 分 就 是 一 个 用 来 求 8 位 二 进 制 数 对 1 补 数 的 电路 。 之 前 提 到 ， 
二 进 制 数 对 1 求 补 数 相当 于 对 其 每 位 取 反 ， 因 此 我 们 计算 8 位 二 进 制 数 补 数 的 时 候 可 以 


9 
YY 


问题 是 ， 该 电路 只 会 对 输入 求 反 ， 而 我 们 要 的 是 一 台 既 能 做 加 法 又 能 做 减法 的 机 器 ， 
因此 就 要 求 该 电路 当 且 仅 当 进行 减法 运算 时 才 实 现 反 转 。 电 路 可 以 改造 为 如 下 图 所 示 。 


标记 为 “ 取 反 ”的 信号 将 被 输入 到 每 一 个 异 或 门 中 。 回 想 一 下 异 或 门 的 工作 方式 ， 
如 下 表 所 示 。 


因此 ， 如 果 “ 到 反 ” 信 和 号 是 0， 则 8 个 异 或 门 输 出 与 输入 相同 。 例 如 ， 如 果 输 入 是 
01100001， 那 么 输出 也 为 01100001。 如 果 “ 取 反 ” 信 号 为 1， 则 输出 信号 反 置 。 例 如 ， 如 
果 输 入 为 01100001， 输 出 则 为 10011110。 
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将 8 个 异 或 门 合 并 起 来 画 成 一 个 器 件 ， 称 为 求 补 器 ( One’s Complement )， 如 下 所 示 。 
J a | 
lay Inx 


tns In: mi {fas in ins 


取 反 


求 补 器 
i | 
将 一 个 求 补 器 ， 一 个 8 位 二 进 制 加 法 器 和 一 个 异 或 门 做 如 下 连接 。 
及 输入 号 输入 
上 和 
GD 反 
ED 求 补 器 


8 位 加 法 器 
S7.S0 


上 道 / 下 洪 
和 输出 


注意 ,这 里 三 个 信号 都 标识 为 “SUB”， 这 就 是 加 /减法 转换 开关 。 当 该 信号 为 0 的 时 
候 , 其 进行 的 是 加 法 运算 , 为 1 时 进行 的 则 是 减法 运算 。 在 减法 中 , 输入 B (第 二 排 开 关 ) 
在 送 入 加 法 器 之 前 ， 需 先 通过 求 补 电路 进行 取 反 。 此 外 ， 在 做 减法 时 ， 我 们 通过 设 定 CI 
(进位 输入 ) 为 1 来 使 得 结果 加 1。 而 在 加 法 中 ， 求 补 电 路 将 不 起 作用 ， 且 输入 CI 为 0。 

加 法 器 的 SUB 信号 和 CO ( 进位 输出 ) 输出 作为 异 或 门 的 输入 来 控制 表示 上 溢 / 下 溢 
的 灯泡 。 如 果 SUB 信号 为 0 ( 表示 进行 加 法 运算 )， 则 当 加 法 器 CO 输出 为 1 时 灯亮 , 意 
思 是 加 法 计算 结果 大 于 255。 


当 进 行 减法 运算 的 时 候 ， 如 果 减 数 〈 输入 B ) 小 于 被 减 数 (输入 A )， 这 时 加 法 器 的 
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| 


CO 输出 为 1。 这 表示 减法 的 最 后 一 步 要 减 去 100000000。 也 就 是 说 碱 数 要 大 于 被 碱 数 ， 
结果 为 负 。 上 面 所 示 器 件 现 在 还 不 能 表示 负数 。 因 此 ， 上 溢 / 下 溢 指 示 灯 仅 在 加 法 器 的 CO 
输出 为 0 时 才 会 亮 起 。 


本 


:应 该 会 庆 笠 自 己 问 了 这 个 问题 :“ 减 法 该 如 何 实现 呢 ? ” 


网 


本 章 一 直 在 谈论 负数 ， 但 是 并 没有 提 到 负数 在 二 进 制 中 是 如 何 表 示 的 。 你 可 能 设想 
二 进 制 会 同 十 进 制 一 样 应 用 传统 的 负数 符号 。 例 如 ， 77 在 二 进 制 中 为 -1001101。 这 样 做 
当然 可 以 ， 但 是 应 用 二 进 制 数 的 目的 恰恰 就 在 于 只 希望 用 0 和 1 来 表示 所 有 的 东西 ， 当 
然 也 包括 负 号 。 


.当然 ， 你 可 以 简单 地 用 一 个 二 进 制 位 来 表示 负 号 ， 当 这 一 位 为 1 的 时 候 就 表示 负数 ， 
为 0 则 表示 正 数 ， 尽 管 这 样 也 是 可 行 的 ， 但 还 远 远 不 够 。 还 有 男 一 种 方法 可 以 解决 负数 的 表 
示 问 题 ， 而 且 它 还 可 以 很 轻松 地 让 负数 和 正 数 相 加 。 这 种 方法 的 缺点 是 必须 提前 算 一 下 可 能 
遇 到 的 所 有 数字 的 位 数 。 


让 我 们 来 想 一 想 。 通 常用 来 表示 正 数 和 负数 的 方法 ， 其 好 处 就 在 于 能 表示 所 有 的 正 
数 、 负 数 。 我 们 将 0 想象 为 这 个 无 限 延 伟 的 序列 的 中 点 。 这 个 序列 中 正 数 沿 着 一 个 方向 
延伸 ， 而 负数 则 按照 另 一 个 方向 延伸 : 


… 一 1000000，-999999…-3，-2，-1，0，1，2，3…999999，1000000… 


但 是 ， 如 果 我 们 并 不 需要 无 限 大 或 无 限 小 的 数 ， 而 且 在 开始 的 时 候 我 们 就 可 以 预知 
所 使 用 的 数字 的 范围 ， 那 情况 就 有 所 不 同 了 。 


以 支票 账户 为 例 ， 这 里 人 们 通常 会 遇 到 负数 。 假 设 我 的 账户 余额 不 超过 500 美元 ， 
并 且 银 行 给 了 我 们 500 美元 的 无 息 预 支 额度 ， 意 思 就 是 账户 余额 数值 应 该 是 一 个 在 499 
美元 到 -500 美元 之 间 的 数 。 假 设 我 们 不 会 一 次 取出 500 美元 ， 我 们 也 不 会 支出 多 于 500 
美元 的 金额 ， 这 里 我 们 用 到 的 只 是 美元 ， 不 涉及 美 分 。 


这 些 假设 表明 账户 能 处 理 的 额度 是 介 于 -500 到 499 之 间 ， 总共 1000 个 数 。 这 个 约束 
说 明 只 用 三 位 十 进 制 数 ， 且 不 用 负 号 就 可 以 表示 所 有 需要 的 数字 。 我 们 并 不 需要 用 到 从 
500 到 999 之 间 的 正 数 ， 因 为 我 们 所 需要 的 数 的 最 大 值 为 499。 因 此 从 500 到 999 的 三 位 
数 可 以 用 来 表示 负数 。 有 具体 情况 如 下 : 
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Rs 


汪 


5$00 表示 -500 
用 501 表示 -499 
用 502 表示 -498 


日 998 表示 -2 
用 999 表示 -1 
用 000 表 示 0 
用 001 表示 1 
用 002 表示 2 


用 497 表示 497 


人 
性 
© 
© 
S 
dl 
人 
DD 
DD 


也 就 是 说 ， 以 5，6，7, 8 或 9 开头 的 三 位 数 实际 上 表示 的 都 是 负数 ， 而 不 是 把 数字 
写成 这 样 : 


—500, —499, -498 … -4, -3, -2, —1, 0, 1, 2, 3, 4 … 497, 498, 499 


用 这 种 表示 法 ,我 们 可 以 将 它们 写成 : 

500, 501, 502 … 996, 997, 998, 999, 000, 001, 002, 003, 004 … 497, 498, 499 
注意 ， 这 就 形成 了 一 个 循环 排序 。 最 小 的 负数 ( 500 ) 看 起 来 像 是 最 大 正 数 ( 499 ) 
的 延续 。 而 数字 999 ( 实际 上 是 -1 ) 是 比 0 小 1 的 第 一 个 负数 。 如 果 我 们 在 999 上 加 1， 
通常 会 得 到 1000。 由 于 我 们 处 理 的 是 三 位 数 ， 这 个 结果 实际 上 就 是 000。 


这 种 标记 方法 称 为 10 的 补 数 (ten's complement )。 为 了 将 三 位 负数 转化 为 10 的 补 数 ， 
我 们 用 999 减 去 它 再 加 1。 也 就 是 说 ， 对 10 求 补 数 就 是 对 9 的 补 数 再 加 1。 例 如 想 要 得 
到 -255 对 10 的 补 数 ， 用 999 减 去 255 得 到 744， 然 后 再 加 1， 得 到 745。 


你 可 能 听 说 过 :“ 减 一 个 数 就 等 于 加 一 个 负数 。” 你 可 能 会 回答 :“ 实 际 上 还 是 减 去 了 
这 个 数 。” 然 而， 利用 10 的 补 数 ， 我 们 将 不 会 再 用 到 减法 。 所 有 的 步 又 都 用 加 法 来 进行 。 
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下 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


假设 你 有 一 个 余额 为 143 美元 的 支票 账户 。 你 天 
要 将 一 个 值 为 负 的 78 美元 加 到 143 美元 凸 。-78 对 10 的 补 数 为 999-078+1 ， 


F 了 一 张 78 美元 的 支票 ， 也 就 意味 着 
即 922。 因 


此 新 余额 为 143 美元 +922 美元 ， 相 当 于 65 美元 ( 忽略 溢出 )。 如 果 我 们 又 开 了 一 张 150 
美元 的 支票 , 需要 在 余额 上 加 上 -150, -150 对 10 求 补 数 为 850。 因此 先前 的 余额 加 上 850 


等 于 915， 


就 是 新 的 账户 余额 。 而 这 个 余额 实际 上 是 -85 美元 。 


这 样 的 机 制 在 二 进 制 中 被 称 为 2 的 补 数 。 以 8 位 二 进 制 数 为 例 。 


11111111， 对 应 十 进 制 中 的 0~ 255。 


位 数 都 表示 一 个 负数 ， 如 下 表 所 示 。 


十 进 制 数 


| 


00000000 
00000001 
10000010 


01111110 
O1111111 


2 


一 
0 


范围 为 00000000 ~ 
但 是 如 果 你 还 想 表示 负数 的 话 ， 则 以 1 开头 的 每 个 8 


现在 所 表示 的 数 的 范围 是 -128 ~ +127。 最 高 有 效 位 (最 左 位 ) 作为 符号 位 ( sign bit )。 


符号 位 


为 了 计算 2 的 补 数 ， 则 首先 要 计算 1 的 补 数 ， 然 后 再 加 1。 这 等 价 于 将 每 位 取 反 再 


ph ，1 表示 负数 ，0 表示 正 数 。 


了 加 


1。 例 如 ， 十进制 数 125 写 为 二 进 制 为 01111101。 为 了 表示 -125 的 对 2 的 补 数 ， 首 先 将 
01111101 的 每 位 取 反 ， 得 到 10000010， 再 加 1， 得 到 10000011。 可 以 根据 前 面 的 表格 核 
实 一 下 结果 。 用 同样 的 步骤 ， 每 位 取 反 调 加 1， 可 以 将 数值 还 原 。 
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这 个 系统 为 我 们 提供 了 种 不 用 负 号 就 能 表示 正 、 负 数 的 方法 。 同样 也 让 我 们 自由 地 
将 正 数 和 负数 用 加 法 法 则 相 加 。 例 如 ， 将 与 -127 和 124 等 价 的 两 个 二 进 制 数 相 加 。 利 用 
上 面 的 表格 ， 可 以 简单 地 写 为 


OODGODY 
于 从 是 下 于 玫 和 四 人 
全 重生 人 和 个 人 


结果 等 于 十 进 制 的 -3。 


要 注意 的 是 ， 这 里 涉及 了 上 谥 和 下 谥 情况 ， 即 结果 大 于 127 或 小 于 -128。 例 如 ， 将 
125 与 它 自身 相 加 : 


O1114401 
十 半生 下 计生 全 四 和 
生生 生生 全 和 各 


于 最 高 位 为 1， 结 果 代 表 一 个 负数 ， 相 当 于 十 进 制 的 数 -6。 将 -125 与 它 本 身 相 加 
也 会 出 现 同 样 的 情况 : 


140000011 
+ 10000011 
40000311 放 


在 一 开始 ,我 们 规定 所 处 理 的 数值 为 8 位 ， 因 此 最 左 位 被 忽略 。 右 边 % 位 相当 于 十 
进 制 的 +6。 | 


一 般 来 说 ， 如 果 两 个 操作 数 的 符号 相同 ， 而 结果 的 符号 与 操作 数 的 符号 不 相同 ， 这 
样 的 加 法 就 是 无 效 的 。 


现在 ， 二进制 数 可 以 有 两 种 不 同 的 使 用 方法 。 二 进 制 数 可 以 是 有 符号 的 ， 也 可 以 是 
无 符号 的 。 无 符号 的 8 位 二 进 制 数 所 表示 的 范围 是 0~ 255。 有 符号 的 8 位 二 进 制 表示 的 
范围 是 -128~ 127。 无 论 是 有 符号 的 还 是 无 符号 的 ， 数 字 本 身 是 无 法 显示 的 。 例 如 ， 如 果 
有 一 个 人 问 :“ 有 一 个 8 位 二 进 制 数 ， 值 为 10110110。 它 相当 于 十 进 制 的 多 少 ? ”你 必须 
先 问 :“ 它 是 有 符号 数 还 是 无 符号 数 ? 它 可 能 为 -74 或 者 182。” 


这 就 是 二 进 制 数 的 麻烦 之 处 ， 它 们 只 是 一 些 0 和 1， 本身 并 没有 任何 含义 。 
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HI 


很 多 电器 中 都 装 了 


反 冉 与 触发 硼 


甩 可 以 让 物体 运动 ， 这 个 道理 人 人 都 懂 。 只 要 稍微 扫 视 一 下 我 们 的 房间 就 会 发 现 : 
和 动机， 比如 钟表 、 电 扇 、 食 品 加 工 器 ， 以 及 CD 播放 名 等 。 电 同样 可 


以 使 扩 音 器 中 的 磁 芯 振动 ， 正 因为 如 此 我 们 的 音响 设备 、 电 视 机 才能 够 产生 声音 ， 播 放 
语音 和 音乐 。 有 一 类 设备 或 许 能 很 清晰 地 图 释 电 能 驱使 物体 运动 的 最 简单 也 最 上 其 代表 性 
的 方式 , 然而 由 于 这 类 设备 正在 被 能 够 实现 同样 功能 的 电子 器 件 逐 步 取代 , 它们 正在 迅 
速 地 消失 。 在 我 看 来 ， 最 令 人 赞叹 的 例子 应 该 算是 电子 蜂 鸣 器 和 电 铃 了。 


将 继电器 、 


池 、 玫 


Ff 关 按 如 下 形式 连接 。 
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如 果 你 认为 这 个 系统 看 起 来 有 点 古怪 ， 说 明 你 还 没有 发 挥 出 想象 力 。 或 许 以 前 我 们 
没 见 过 采用 这 种 连接 方式 的 继电器 ， 因 为 我 们 通常 所 见 过 的 继电器 ， 其 输入 和 输出 是 分 
开 的 ， 而 这 里 却 构成 了 一 个 回路 。 当 开关 闭合 后 ， 电 路 就 连通 了 。 


连通 的 电路 使 得 电磁 铁 把 金 
当 金 属 簧 片 的 位 置 变 化 时 ， 9 连通 ， 电 磁铁 不 再 具有 人 磁性， 金属 簧 片 又 弹 回 
原 位 。 
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3 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


如 此 一 来 ， 电 路 又 一 次 连通 了 。 从 整个 过 程 来 看 : 开关 一 旦 闭合 ， 金 属 簧 片 就 会 上 
下 跳动 一 电路 也 会 随 之 连通 或 断 开 一 一 声音 也 就 会 随 之 发 出 。 如 果 金 属 簧 片 发 出 了 一 种 
刺耳 的 声音 , 这 套 系统 就 成 为 了 一 个 蜂 鸣 器 。 如 果 人 金属 赞 片 前 端 是 一 把 小 锤子 ,旁边 只 
要 放 上 一 个 锣 ， 就 构成 了 一 个 电 铃 。 


有 两 种 方法 可 以 使 继电器 连接 成 为 一 个 蜂 鸣 器 ， 下 面 再 给 出 一 种 方法 的 描述 ， 在 示 
意图 中 包含 了 一 个 标准 电压 符号 和 一 个 接地 符号 。 


看 到 这 幅 图 你 或 许 立刻 想起 了 第 11 章 介 绍 过 的 反 向 器 ， 因 此 电路 可 以 简化 为 如 下 图 


所 示 。 
GE 


正如 你 所 记得 的 那样 ， 当 反 向 器 的 输入 是 0 的 时 候 ， 它 的 输出 就 为 1; 而 当 其 输入 为 
1 时 ， 输 出 就 为 0。 电 路 中 的 开关 一 旦 闭合 ， 反 向 器 中 的 继电器 就 会 在 连通 与 断 开 这 两 种 
状态 之 间 反 复 交 蔡 。 你 也 可 以 将 电路 中 的 开关 省 去 ， 这 样 就 可 以 使 反 向 器 连续 地 工作 ， 


如 下 所 示 。 
> 


这 幅 图 似乎 在 表达 着 一 种 矛盾 的 逻辑 ， 反 向 器 的 输出 与 其 输入 是 相反 的 ， 但 是 在 这 
里 ， 输 出 同时 又 是 输入 ! 然而 ,我 们 要 和 牢 牢 记 住 ， 反 向 器 在 本 质 上 就 是 一 个 继电器 ， 而 
继电器 将 状态 取 反 以 得 到 另 一 个 状态 是 需要 一 点 点 时 间 的 。 所 以 ， 即 使 输入 和 输出 是 相 
同 的 ， 输 出 也 会 很 快 地 改变 ， 成 为 输入 的 相反 状态 〈 当然 ， 输 出 随即 也 会 很 快 改变 输入 ， 
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如 此 反复 )。 


电路 的 输出 是 什么 呢 ? 其 实 就 是 要 么 提供 电压 ， 要 么 不 提供 电压 ， 在 两 者 之 间 切 换 。 
我 们 也 可 以 换 种 方式 来 表达 一 一 输出 结果 要 么 是 0， 要 么 是 1。 


我 们 把 这 种 电路 称 为 振荡 器 ( oscillator )， 它 和 我 们 先前 学 到 的 所 有 东西 存在 本 质 上 
的 区 别 。 在 此 之 前 我 们 讲 过 的 所 有 的 电路 ， 其 状态 的 改变 都 依靠 人 为 的 干预 ， 通 常 是 通 
过 改变 开关 状态 来 实现 的 。 但 是 振荡 器 却 在 不 需要 人 干涉 的 情况 下 ， 可 以 完全 自发 地 工 
”人 帮 。 


当然 ， 单 独 的 一 个 振荡 器 用 处 并 不 大 ， 但 是 在 本 章 的 后 面 和 接 下 来 的 几 章 里 ， 我 们 
会 发 现 ， 在 与 其 他 电路 连接 后 所 组 成 的 自动 控制 系统 中 ， 振 荡 器 有 着 举足轻重 的 作用 。 
为 了 使 不 同 组 件 同步 工作 ， 所 有 计算 机 都 配备 着 某 种 振荡 器 。 


当 采 用 0 和 1 的 交 蔡 序列 来 表示 振荡 器 的 输出 时 ， 我 们 一 般 使 用 下 面 这 样 的 图 来 形 


象 地 描述 输出 。 


我 们 可 以 通过 这 幅 图 来 充分 地 了 解 电路 的 输出 ， 水 平 坐标 代表 时 间 ， 垂 直 坐 标 用 来 
表示 输出 是 0 还 是 1。 


1 
LT ii 
村 痊 
这 幅 图 表示 随 着 时 间 的 推移 ， 振 荡 器 的 输出 在 0 和 1 之 间 按 照 固 有 的 规律 交 蔡 变化 。 
正 因为 这 一 点 , 振荡 器 又 经 常 被 称 为 时 钟 (clock ), 通过 振荡 进行 计数 也 是 一 种 计时 方式 。 
振荡 器 运行 速度 究竟 有 多 快 昵 ?” 换 句 话 说 ,金属 繁 片 多 久 会 振动 一 次 ?或 者 每 秒 钟 


振动 多 少 次 呢 ? 这 很 大 程度 上 依赖 于 继电器 的 内 部 构造 。 你 容易 想到 ， 一 个 又 大 又 重 的 
继电器 只 能 缓慢 地 上 下 摆动 ; 而 一 个 又 小 又 轻 的 继电器 却 可 以 高 速 地 跳动 。 


振荡 器 从 某 个 初始 状态 开始 ， 经 过 一 段 时 间 又 回 到 先前 初始 状态 的 这 一 段 间隔 定义 
为 振荡 器 的 一 个 循环 ( cycle )， 或 者 称 为 一 个 周期 ， 如 下 图 所 示 。 
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一 下 纺 可 一 丰 基 在 | 算 机 罗 硬 人 有 后 的 请 言 


3 


一 个 循环 所 占用 的 时 间 就 是 该 振荡 器 的 周期 (period )。 假 设 我 们 使 用 的 振荡 器 的 周 
期 恰好 是 0.05s， 任 取 一 个 时 间 点 ， 将 其 设置 为 起 始 状态 点 ， 我 们 把 它 标注 为 零点 ， 就 可 
以 在 水 平 轴 上 标 出 相应 的 时 间 。 


一 个 特 环 
让 
0 


: (s) 
0 VO2S O05 O75 O10 O125 0.15 竺 间 


周期 的 倒数 就 是 振荡 器 的 频率 ( frequency )。 在 这 个 例子 中 振荡 器 的 周期 是 0.0$s, 那 
么 其 频率 就 是 1= 0.05s， 即 振荡 器 每 秒 钟 产生 20 次 循环 ， 而 相应 的 输出 每 秒 钟 也 变化 20 
次 。 


每 秒 钟 的 循环 次 数 与 每 小 时 穿越 的 英里 数 、 每 平方 英尺 的 重量 、 每 份 食物 的 卡路里 
数 等 概念 一 样 都 是 很 容易 理解 的 ， 但 这 种 描述 方法 已 不 常用 。 为 了 纪念 发 送 和 接收 无 线 
昌 波 的 第 一 人 一 一 亨利 希 . 鲁 道 夫 : 赫兹 (1857-1894 )， 后 人 使 用 “赫兹 ”这 个 词 来 表 
示 这 一 概念 。 这 种 用 法 起 源 于 20 世纪 20 年 代 的 德国 ， 几 十 年 之 后 逐渐 被 其 他 国家 所 广 
泛 采 纳 。 

这 样 ， 上 述 振荡 器 的 频率 就 是 20 赫兹 ， 记 做 20 Hz。 

目前 为 止 ， 我 们 还 只 是 在 猜测 一 个 振荡 器 的 速度 。 在 本 章 后 面 我 们 将 构建 一 种 可 以 
测量 振荡 器 速度 的 元 件 。 

在 此 之 前 ， 让 我 们 先 来 看 看 采用 特殊 方式 连接 的 一 对 或 非 门 。 或 非 门 的 特点 是 只 有 
在 两 个 输入 端 都 没有 电压 时 ， 输 出 端 才 产生 电压 。 
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值得 入 


意 的 是 这 种 特殊 的 弯 


的 连 线 方式 : 左边 或 非 门 的 答 出 是 右边 或 非 门 的 输入 ， 


而 右边 或 非 门 的 输出 是 左边 或 非 门 的 输入 。 这 种 连接 方式 我 们 称 之 为 反馈 ( feedback )。 
系统 的 输出 返回 给 输入 这 种 形式 和 我 们 在 振荡 器 中 讨论 的 情况 很 相似 。 接 下 来 你 将 会 看 
到 ， 本 章 大 部 分 电路 都 具备 这 种 特质 。 


在 初始 状态 下 ,电路 中 只 有 左边 的 或 非 门 输出 电流 ,这 是 因为 其 两 个 输入 均 为 0。 让 


我 们 闭合 上 面 的 开关 ， 左 边 或 非 门 将 立刻 输出 0， 右 边 或 非 门 的 输出 也 会 随 之 变 为 1， 这 
时 灯泡 将 被 点 亮 。 


奇妙 的 是 ， 这 时 一 旦 你 关闭 上 边 的 开关 ， 灯 炮 依 然 内 闪 发 光 。 这 是 因为 由 于 左边 或 
非 门 的 输入 中 有 一 个 为 1， 其 输出 依然 是 0， 因而 左边 或 非 门 的 输出 不 变 ， 所 以 灯泡 仍然 


亮 着 。 
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编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


难道 你 不 觉得 有 点 奇怪 吗 ? 两 个 开关 都 断 开 一 一 和 第 一 幅 场景 描述 的 是 一 模 一 样 一 
一 但 这 里 的 灯泡 却 仍 发 光 。 这 与 我 们 先前 所 见 过 的 所 有 情况 都 完全 不 同 。 先 前 遇 到 的 电 
路 其 输出 依赖 旦 仅 依赖 于 其 输入 ， 这 次 的 结论 与 以 前 的 大相径庭 。 无 论 上 面 的 开关 怎么 
调整 其 状态 ， 灯 泡 总 是 亮 着 。 这 个 开关 对 电路 毫 无 影响 ， 究 其 原因 可 以 发 现 这 是 由 于 左 
边 或 非 门 的 输出 一 直 为 0。 

现在 来 试 试 闭合 下 面 的 开关 。 我 们 会 发 现 右边 或 非 门 的 输入 中 有 一 个 立 肇 变 为 1, 其 
输出 就 相应 地 变 为 0， 灯泡 随 之 熄灭 。 左 边 或 非 门 的 输出 此 刻 变 为 1。 


此 时 的 电路 状态 与 初始 时 是 一 样 的 。 但 是 这 次 无 论 你 怎么 改变 下 面 开 关 的 状态 ， 灯 
泡 丝 毫 不 受 影 响 。 我 们 将 先前 的 情况 一 起 总 结 一 下 : 

% 接 通 上 面 的 开关 ， 灯 泡 被 点 亮 ， 断 开 此 开关 灯泡 仍然 亮 着 。 

4 接 通 下 面 的 开关 ， 灯 泡 被 熄灭 ， 断 开 此 开关 灯泡 仍然 不 亮 。 
路 的 奇怪 之 处 是 : 同样 是 在 两 个 开关 都 断 开 的 状态 下 ， 灯 泡 有 时 亮 着 ， 有 时 却 不 
亮 。 当 两 个 开关 都 断 开 时 ， 电 路 有 两 个 稳定 态 ， 这 类 电路 统称 为 触发 器 ( Flip-Flop )， 
Flip-Flop 这 个 单词 也 可 以 有 “沙滩 鞋 ” 或 者 是 “政治 策略 ”的 意思 。 触 发 器 是 在 1918 年 
被 发 明 的 ， 发明 者 是 英国 无 线 电 物理 学 家 威廉 姆 : 享 利 . 艾 克 里 斯 ( 1875-1966 ) 和 F.W. 
乔丹 (信息 不 详 )。 
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触发 器 电路 可 以 保持 信息 ， 它 可 
述 的 触发 器 ， 它 可 以 记 住 最 近 一 次 是 哪个 刀 
果 它 的 灯泡 是 亮 着 的 ， 你 就 可 以 推测 出 最 后 
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以 “ 记 住 ” 某 些 信 息 。 特 别 地 ， 对 于 本 章 先 前 所 讲 
F 关 先 闭合 。 如 果 你 遇 到 这 样 一 种 触发 器 ， 如 


则 可 推测 出 最 后 一 次 连通 的 是 下 面 的 开关 。 


触发 器 和 路 跷 板 有 着 很 强 的 相似 性 。 跷 跷 板 也 有 两 个 稳定 状态 ， 它 不 会 长 期 停留 在 
不 稳定 的 中 间 位 置 。 通 过 观察 跷 跷 板 ， 我 们 很 容易 推测 出 哪 边 最 后 一 次 被 压 下 来 。 
能 还 没 感受 到 这 一 点 ， 但 触发 器 的 的 确 确 是 一 种 必 不 可 少 的 工具 。 它 
”之 前 发 生 了 什么 事情 。 想 象 一 下 ， 如 果 你 没有 了 记忆 力 ， 该 如 何 


尽管 你 现在 可 
们 可 以 让 电路 “ 记 人 


CR 


次 连通 的 是 上 面 的 开关 ; 而 和 如果 灯泡 不 亮 


去 数 数 ， 我 们 不 记得 刚刚 数 过 的 数 ， 当 然 也 就 无 法 确定 下 一 个 数 是 什么 ! 同 理 ， 一 个 能 
计数 的 电路 ( 本 章 后 面 要 讲 到 ) 必定 需要 触发 器 。 


触发 器 种 类 繁多 , 先前 所 讲述 的 是 最 简单 


的 一 种 R-S ( Reset-Set, 复位 / 置 位 ) 触发 器 。 


我 们 通常 把 两 个 非 或 门 绘 制 成 男 一 种 形式 ， 加 上 标识 符 就 得 到 了 下 面 这 幅 图 。 
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我 们 通常 ] 


| Q 来 表示 用 了 
Q 的 取 反 。Q 是 0，Q 就 是 1， 反 之 了 


点 亮 灯 泡 的 输 日 


的 状态 。 另 一 个 输出 Q 〈 读 做 Q 到 ) 是 对 


下 然 。 输 入 端 S ( Set.) 用 来 置 位 ，R (Reset ) 用 来 复 


位 。 你 可 以 把 “ 置 位 ”理解 为 把 Q 设 为 1， 而 “复位 ”是 把 Q 设 为 0。 当 状态 $ 为 1 时 
(对 应 于 先前 触发 器 中 上 面 的 开关 闭合 的 情况 
1 时 (对 应 于 前 面 图 中 闭合 下 面 的 开关 的 情况 


为 0 时 ， 输 出 保持 Q 原来 的 状态 不 变 。 我 们 把 结论 总 结 如 下 表 所 示 。 


)， 此 时 Q 变 为 1 而 Q 变 为 0; 当 有 R 状态 为 
)， 此 时 Q 变 为 0 而 Q 变 为 1。 当 S$ 和 及 均 
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这 类 表 称 为 功能 表 ( function table )、 逻 辑 表 (logic table ) 或 真 值 表 (truth table )。 它 
表达 了 不 同 输入 组 合 所 对 应 的 不 同 输出 结果 。 因 为 R-S 触发 器 仅 有 两 个 输入 端 ， 所 以 不 
同 的 输入 组 合共 有 4 种 ， 分 别 对 应 于 表 中 的 4 行 。 


注意 表 中 倒数 第 2 行 ; 这 一 行 输入 S 和 及 均 为 0， 而 输出 标识 为 Q 和 Q 。 这 表示 当 
S 入 输入 均 为 0 时 , Q 和 Q 端的 输出 保持 为 S、R 同时 被 设 为 0 以 前 的 输出 值 。 表 中 最 
后 一 行 表示 S 和 R 均 为 1 的 输入 组 合 是 被 禁止 或 者 不 合法 的 。 不 要 误解 为 你 会 因此 被 
逮捕， 而 是 说 如 果 S、R 状态 同时 为 1 时 ，Q 和 Q 均 会 为 零 , 这 与 Q 和 Q 互 反 的 假设 关 
系 相 矛盾 。 所 以 当 使 用 R-S 触发 器 进行 电路 设计 时 ，R、S 输入 同时 为 1 的 情况 一 定 要 
避免 。 


R-S 触发 器 可 以 简化 为 带 有 输入 和 输出 标志 的 小 框图 ， 就 像 下 面 画 的 这 样 。 


| 
汉 
| 1 


R-S 触发 器 最 突出 的 特点 在 于 ， 它 可 以 记 住 哪个 输入 端的 最 终 状 态 为 1。 但 是 有 时 候 
我 们 需要 一 种 记忆 能 力 更 加 强大 的 电路 , 例如 能 记 住 在 某 个 特定 时 间 点 上 的 一 个 信号 是 0 


还 是 1。 


在 构造 具备 这 种 功能 的 电路 之 前 ， 让 我 们 先 来 思考 一 下 它 的 具体 行为 。 这 个 电路 存 
在 两 个 输入 。 其 中 一 个 我 们 称 之 为 数据 端 ( Data )。 与 所 有 数字 信号 一 样 ， 数 据 端 取 值 为 
0 或 1; 另 一 个 输入 被 称 为 保持 位 ( Hold That Bit ), 保持 位 的 作用 就 是 使 当前 的 状态 被 “ 记 
住 ”， 通 党 情况 下 保持 位 被 设置 为 0， 在 这 种 情况 下 数据 端 对 电路 不 产生 影响 。 当 保持 位 
置 1 时 ， 数 据 端的 值 就 会 在 电路 系统 中 被 “ 记 住 "。 随 后 保持 位 又 置 为 0， 这 时 电路 已 经 
“ 记 住 ”了 数据 端的 最 后 一 次 输入 ， 而 之 后 数据 端的 输入 无 论 如 何 变化 都 不 会 对 电路 产生 


我 们 可 以 把 状态 转化 的 过 程 以 真 值 表 的 形式 表示 如 下 。 
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在 前 两 种 情况 下 ,保持 位 为 1, 输出 Q 与 数据 端 输入 相同 ; 后 面 两 种 情况 下 , 保持 位 
为 0, 输出 端 Q 和 其 前 一 个 状态 保持 一 致 。 值 得 注意 的 是 , 保持 位 为 0 意味 着 输出 将 不 再 
变化 ， 也 就 是 说 不 再 被 数据 端 所 影响 ,我 们 可 以 进一步 将 真 值 表 简 化 为 如 下 所 示 。 


-> 


和 表示 “其 取 值 情况 与 结果 无 关 " ， 只 要 保持 位 的 值 为 0， 那 么 数据 位 对 电路 的 输 
没有 影响 ， 电 路 的 输出 和 其 前 一 个 状态 相同 。 
如 果 使 用 先前 学 过 的 R-S 触发 器 来 实现 这 种 具有 保持 位 的 功能 系统 ， 那 么 我 们 的 电 
路 需要 在 输入 端 增加 两 个 与 门 ， 下 图 所 给 出 了 该 系统 的 实现 电路 。 
复位 


TL 


保持 位 


置 位 


回忆 一 下 与 门 , 它 的 特点 是 只 有 在 输入 端 都 为 1 的 状态 下 , 输出 才 为 1。 在 上 面 这 幅 图 中 ， 
输出 端 Q 为 0，Q 为 1。 


只 要 保持 位 为 0， 则 置 位 端 对 于 输出 结果 不 会 有 任何 影响 。 
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复位 


保持 科 


置信 
同样 ， 复 位 信号 对 输出 也 无 任何 影响 。 
每 入 we 


这 时 由 于 上 面 与 门 的 输出 和 复位 端 输 入 相同 ， 而 下 面 与 门 的 输出 和 置 位 端 输入 相同 ， 
所 以 电路 系统 的 功能 和 普通 的 R-S 触发 器 是 一 样 的 。 


但 是 我 们 离 目标 还 差 一 点 。 我 们 只 想 要 两 个 输入 ， 而 不 是 三 个 ， 怎 么 解决 这 个 问题 
呢 ? 先 回忆 一 下 R-S 触发 器 的 功能 表 : 两 个 输入 端 同时 为 1 是 非法 的 ， 要 尽量 避免 ; 而 
两 个 输入 端 同时 为 0 是 无 意义 的 ， 因 为 那 种 情况 下 输出 就 会 保持 不 变 。 我 们 只 要 将 保持 
位 设置 为 0， 就 完全 可 以 实现 相同 的 功能 。 

由 此 可 以 总 结 出 ， 真 正 有 意义 的 输入 可 以 是 $ 为 0, R 为 1 或 者 是 R 为 0，S 为 1 的 
情形 。 如 果 把 数据 端 信号 看 做 置 位 信号 ， 把 它 取 反 后 的 值 看 做 复位 端 信号 ， 我 们 可 以 画 
出 相应 的 电路 图 如 下 所 示 。 
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在 上 图 所 表示 的 情况 下 ， 所 有 输入 均 为 0， 而 输出 Q 也 为 0 (此 时 Q 为 1)。 可 以 看 
出 只 要 保持 位 为 0， 电 路 输出 就 丝毫 不 受 输入 端的 影响 。 


现在 Q 端的 输出 和 数据 输入 是 一 致 的 ， 而 Q 端 则 正好 相反 。 现 在 保持 位 又 回 到 0， 
如 下 图 所 示 。 
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这 时 ， 电 路 会 “记得 ” 当 保 持 位 最 后 一 次 置 1 时 数据 端 输入 的 值 ， 数 据 端 的 变化 对 
此 没有 影响 。 例 如 ， 数 据 端 再 置 回 0 对 输出 将 不 会 产生 影响 。 


这 个 电路 称 为 电 平 触发 的 DD 型 触发 器 ，D (Data ) 表示 数据 端 输入 。 所 谓 电 平 触发 是 
指 当 保持 位 输入 为 某 一 特定 电 乎 〈《 本 例 中 为 “1”) 时 ， 触 发 器 才 保存 数据 端的 输入 值 (很 
快 , 我们 将 看 到 另 一 种 形式 的 触发 器 )。 


通常 情况 下 ， 当 这 种 电路 出 现在 书 中 的 时 候 ， 输 入 端 是 不 会 被 标记 为 保持 位 的 ， 而 
是 被 标记 为 时 钟 ( clock )。 当 然 ， 这 种 信号 并 不 是 真正 的 时 钟 ， 但 是 在 某 些 情况 下 它 却 具 
有 类 似 时 钟 的 属性 ， 即 它 可 以 在 0 和 1 之 间 有 规律 地 来 回 变化 。 但 是 现在 时 钟 仅 仅 用 来 
指示 什么 时 候 保存 数据 。 


这 个 电路 也 就 是 所 谓 的 电 平 触发 的 D 型 锁 存 器 ， 它 表示 电路 锁 存 住 一 位 数据 并 保持 
它 ， 以 便 将 来 使 用 。 这 个 电路 也 可 以 被 称 为 1 位 存储 器 。 在 本 书 的 第 16 章 将 会 介绍 如 
何 将 多 个 1 位 存储 器 连接 起 来 构成 多 位 存储 器 。 
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在 锁 存 器 中 保存 多 位 值 通常 是 很 有 用 的 。 假 如 你 想 用 第 12 章 的 加 法 器 拒 3 个 8 位 数 
相 加 ， 可 以 在 开关 的 第 1 行 中 存 入 第 1 个 加 数 ， 以 同样 的 方式 把 第 2 个 加 数 存 入 第 2 行 ， 
旧 是 必须 记 下 第 一 次 相 加 的 结果 。 然 后 你 需要 把 这 个 结果 输入 到 开关 的 一 行 中 , 再 把 第 3 
个 加 数 输入 到 开关 的 另 一 行 中 。 而 你 实际 上 不 必 输 入 中 间 结 果 ， 你 应 该 能 够 在 第 一 次 计 
算 之 后 直接 使 用 它 。 

可 以 使 用 锁 存 器 来 解决 这 个 问题 。 我 们 在 一 个 小 盒子 里 布置 8 个 锁 存 器 ， 如 前 所 述 ， 
每 个 锁 存 器 包括 两 个 或 非 门 、 两 个 与 门 以 及 一 个 反 相 器 。 所 有 的 时 钟 输入 端 都 互相 连 在 
一 起 。 结 果 如 下 图 所 示 。 


A 


这 个 锁 存 器 可 以 一 次 保存 8 位 数 。 上 面 的 8 个 输入 端 依次 标记 为 Do。~D;， 下 面 的 8 
个 输出 端 被 标记 为 Qo~ Q;。 左 边 的 输入 是 时 钟 (Clk )， 时 钟 信 号 通常 为 0。 当 时 钟 信号 
为 1 时 , DD 端 输入 的 8 位 值 被 送 到 Q 端 输出 。 当 时 钟 信号 为 0 时 ,这 8 位 值 将 保持 不 变 ， 
直到 时 钟 信号 再 次 被 置 1。 


也 可 以 将 8 位 锁 存 器 的 8 个 数据 输入 端 和 8 个 Q 输出 端 画 为 两 组 线 ， 如 下 图 所 示 。 


下 面 是 8 位 加 法 器 的 图 示 。 
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通常 ( 先 不 考虑 上 一 章 讲 到 的 减法 器 ), 8 个 A 输入 端 和 8 个 B 输入 端 连接 到 开关 上 ， 
”CI (进位 输入 ) 接地 ， 而 8 个 S (计算 和 ) 输出 以 及 CO (进位 输出 ) 端 连 接 到 灯泡 上 。 
经 过 改进 ,8 位 加 法 器 的 8 个 S 输出 端 既 与 灯泡 相连 ,又 连接 到 8 位 锁 存 器 的 数据 (DD ) 
输入 端 。 标 记 为 “保存 ”( Save ) 的 开关 是 锁 存 器 的 时 钟 输 入 ， 用 来 存放 加 法 器 的 运算 结 
果 。 


CO ”8 位 加 法 器 ”I 


灯泡 灯泡 


标识 为 2-1 选择 器 的 方块 是 让 你 用 一 个 开关 来 选择 加 法 器 的 B 端 输入 是 取 自 第 2 排 
开关 还 是 取 自 锁 存 器 的 Q 端 输出 。 当 开关 闭合 时 ， 就 选择 了 用 8 位 锁 存 器 的 输出 作为 B 
端 输入 。2-1 选择 器 使 用 了 8 个 如 下 所 示 的 电路 。 
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B 
选择 端 
输出 
起 


如 果 选 择 端 ( Select ) 输入 是 1， 那 么 或 门 的 输出 和 B 端的 输入 就 是 一 致 的 。 这 是 因 
为 上 面 与 门 的 输出 和 B 端 输 入 是 一 样 的 , 而 下 面 与 门 的 输出 是 0。 类 似 的 ,如果 选择 端的 
输入 是 0， 那么 或 门 的 输出 则 和 A 端 输入 一 致 。 总 结 起 来 如 下 表 所 示 。 


改进 后 的 加 法 器 中 包含 了 8 个 这 样 的 1 位 选择 器 。 所 有 的 选择 端 输入 信号 都 是 连 在 
一 起 的 。 


改进 后 的 加 法 器 不 能 很 好 地 处 理 进 位 输出 〈CO ) 信号 。 如 果 两 个 数 的 相 加 使 得 进位 
输出 信号 为 1， 那么 当下 个 数 被 加 进来 的 时 候 , 这 个 信号 将 被 忽略 掉 。 一 个 可 能 的 解决 方 
案 是 将 加 法 器 、 锁 存 器 、 选 择 器 均 设 置 为 16 位 宽 , 或 者 至 少 应 该 比 你 可 能 遇 到 的 最 大 的 
和 的 位 数 多 一 位 。 这 个 问题 留 到 第 17 章 具体 讲述 。 


对 于 加 法 器 来 说 , 一 个 更 好 的 改进 方法 是 去 掉 一 整 排 8 个 开关 。 但 是 首先 要 对 D 触 
发 器 做 一 些 修 改 ， 为 它 加 一 个 或 门 和 一 个 称 为 清 零 (Clear ) 的 输入 信号 。 清 零 信 号 通常 
为 0， 但 当 它 为 1 时 ，Q 输出 为 0， 如 下 图 所 示 。 


清寺 一 一 ee 


无 论 其 他 信号 是 什么 , 清 零 信号 总 是 强制 使 Q 输出 为 0, 以 达到 使 触发 器 清 零 的 目的 。 
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也 许 你 还 不 明白 为 什么 要 设置 这 个 信号 ， 为 什么 不 能 通过 把 数据 输入 端 置 0 和 把 时 
钟 输入 端 置 1 来 使 触发 器 清 零 呢 ? 这 也 许 是 因为 我 们 无 法 精确 控制 数据 端的 输入 信息 的 
缘故 。 我 们 可 能 有 一 组 8 个 锁 存 器 ， 它 们 连 着 8 位 加 法 器 的 输出 端 ， 如 下 图 所 示 。 


注意 ,标识 为 “ 相 加 ”( Add ) 的 开关 现在 控制 着 锁 存 器 的 时 钟 输入 。 


你 可 能 会 发 现 这 个 加 法 器 比 前 面 的 那个 好 用 ， 特 别 是 当 你 需要 加 上 一 长 串 数 字 时 。 
首先 按 下 清 零 开 关 ， 这 个 操作 会 使 锁 存 器 的 输出 为 0， 并 且 熄 灭 了 所 有 的 灯泡 ， 同 时 使 8 
位 加 法 器 的 第 2 行 输入 全 为 0。 然 后 ,通过 开关 输入 第 一 个 加 数 , 并 且 闭 合 “ 相 加 ”开关 ， 
这 个 加 数 的 值 就 反映 在 灯泡 上 。 再 输入 第 二 个 加 数 并 再 次 闭合 “ 相 加 ”开关 。 由 开关 输 
入 的 8 位 操作 数 加 到 前 面 的 结果 上 ， 所 得 的 和 体现 到 灯泡 上 。 反 复 如 此 操作 ， 可 以 连续 
进行 很 多 次 加 运算 。 


前 面 提 到 过 ， 我 们 所 设计 的 D 触发 器 是 电 平 触发 的 ， 也 就 是 说 为 了 使 数据 端的 值 保 
存在 锁 存 器 中 ， 必 须 把 时 钟 端 的 输入 从 0 变 为 1 即 高 电 平 )。 但 是 ， 当 时 钟 端 输入 为 1 
时 ,数据 端的 输入 是 可 以 改变 的 ， 这 时 数据 端 输入 的 任何 改变 都 会 反映 在 Q 和 Q 的 输出 
值 中 。 


对 某 些 应 用 而 言 ， 电 平 触发 时 钟 输入 已 经 足够 用 了 ;但 是 对 另外 一 些 应 用 来 说 ， 边 
沿 触发 (edge-triggered ) 时 钟 输入 则 更 有 效 。 对 于 边沿 触发 器 而 言 ， 只 有 当时 钟 从 0 跳 变 
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到 1 时 , 才 会 引起 输出 的 改变 。 它 们 的 区 别 在 于 ， 在 电 平 触发 器 中 ， 当 时 钟 输入 为 0 时 ， 
数据 端 输入 的 任何 改变 都 不 会 影响 输出 ;而 在 边沿 触发 器 中 ， 当 时 钟 输入 为 1 时 ， 数 据 
端 输入 的 改变 也 不 会 影响 输出 。 只 有 在 时 钟 输入 从 0 变 到 1 的 瞬间 ， 数 据 端 的 输入 才 会 
影响 边沿 触发 器 的 输出 。 


边沿 触发 的 DD 型 触发 器 是 由 两 级 R-S 触发 器 按 如 下 方式 连接 而 成 的 。 
数据 况 


时 钟 


A 


这 里 ， 时 钟 端的 输入 既 控制 着 第 一 级 R-S 触发 器 ， 也 控制 着 第 二 级 ， 但 是 要 注意 的 是 时 
钟 信 号 在 第 一 级 中 进行 了 取 反 操作 ， 这 意 昧 着 除了 当时 钟 信号 为 0 时 保存 数据 外 ， 第 一 
级 RS 触发 器 和 D 型 触发 器 工作 原理 完全 一 致 。 第 二 级 R-S 触发 器 的 输出 是 第 一 级 的 输 
入 ， 当 时 钟 信号 为 1 时 ， 它 们 都 被 保存 。 一 言 概 之 ， 只 有 当时 钟 信号 由 0 变 为 1 时 ， 数 
据 端 输入 才 被 保存 下 来 。 


进一步 分 析 ， 下 图 为 一 个 处 于 非 工作 状态 的 触发 器 ， 其 数据 输入 和 时 钟 输 入 均 为 0， 
且 Q 输出 也 为 0。 


现在 使 数据 端 输入 为 1， 如 下 图 所 示 。 
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这 改变 了 第 一 级 触发 器 的 状态 ,因为 时 钟 输入 取 反 变 为 1。 但 第 二 级 触发 器 状态 保持 
不 变 ， 因 为 时 钟 输入 仍然 为 0。 现 在 把 时 钟 输入 变 为 1。 


这 就 引起 了 第 二 级 触发 器 输出 的 改变 , 使 Q 输出 变 为 1。 不 同 点 在 于 , 无 论 数据 端 输 
入 发 生 何 种 变化 〈 比方 说 变 为 0 ) 都 不 会 影响 Q 的 输出 。 


只 有 在 时 钟 输入 从 0 变化 到 1 的 瞬间 Q 和 Q 输 出 才 发 生变 化 。 


边沿 触发 的 D 型 触发 器 的 功能 表 需 要 一 个 新 的 符号 来 表示 从 0 到 1 的 瞬时 变化 ， 即 
用 一 个 向 上 的 箭头 (1 ) 表示 ， 如 下 表 所 示 。 
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表 中 箭头 表示 当时 钟 端 由 0 变 为 1 时 ( 称 为 时 钟 信号 的 “ 正 跳 变 ”"，“ 负 跳 变 ”是 指 
从 1 变 为 0)，Q 端 输出 与 数据 端 输入 是 相同 的 。 触 发 器 的 符号 如 下 图 所 示 。 


D Q 
bok © 


图 中 的 小 三 角 符 号 表示 触发 器 是 边沿 触发 的 。 


下 面 展示 的 是 一 个 使 用 边沿 D 型 触发 器 的 电路 ， 这 个 电路 是 不 能 用 电 平 触发 形式 复 
制 出 来 的 。 先 回忆 一 下 本 章 开始 构造 的 振荡 器 ， 其 输出 在 0 和 1 之 间 变 化 。 


把 振荡 器 的 输出 与 边沿 触发 的 D 型 触发 器 的 时 钟 端 输入 连接 ， 同 时 把 Q 端 输出 连接 
到 本 身 的 D 输入 端 。 


这 个 触发 器 的 输出 同时 又 是 它 自己 的 输入 。 反 馈 紧 接 着 反馈 ! (实际 上 ， 这 种 构造 可 
能 是 有 问题 的 ， 振 荡 器 是 由 状态 来 回 迅 速 改 变 的 继电器 构成 的 ， 其 输出 与 构成 触发 器 的 
继电器 相连 ， 而 这 些 其 他 的 继电器 不 一 定 能 跟 得 上 振荡 器 的 速度 。 为 了 避免 这 些 问题 ， 
这 里 假设 振荡 器 中 的 继电器 比 电路 中 其 他 地 方 的 继电器 速度 要 慢 得 多 ) 


仔细 看 一 看 下 面 的 功能 表 就 可 以 明白 在 电路 中 发 生 的 情况 了 ， 电 路 启动 时 ， 假 设 时 
钟 输 入 为 0 且 Q 输 山 也 为 0， 则 Q 端 输出 为 1， 而 Q 是 和 D 端 输入 相连 的 。 
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但 是 由 于 Q 的 输出 变 为 0， 因 此 D 输入 也 变 为 0。 现 在 时 钟 输入 为 1， 如 下 表 所 示 。 


当时 钟 输入 变 回 0 时 ， 不 会 影响 到 输出， 如 下 表 所 示 。 


现在 时 钟 端 输入 又 变 为 1。 
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以 上 发 生 的 现象 可 以 简单 总 结 为 :每 当时 钟 输入 由 0 变 为 1 时 ,Q 端 输出 就 发 生变 化 ， 
或 者 从 0 到 1, 或 者 由 1 到 0。 下 面 的 时 序 图 可 以 更 加 清楚 地 说 明 这 个 问题 。 


当时 钟 端 Clk 输入 由 0 变 为 1 时 , D 的 值 (与 Q 的 值 相同 ) 被 输出 到 Q 端 。 当 下 一 
次 CIk 信号 由 0 变 为 1 时 ，D 和 Q 的 值 同样 会 改变 。 


如 果 这 个 振荡 器 的 频率 是 20Hz ( 即 20 个 周期 的 时 间 为 ls )， 那么 Q 的 输出 频率 是 它 “ 
的 一 半 ， 即 10Hz， 由 于 这 个 原因 ， 这 种 电路 称 为 分 频 器 (frequency divider )， 它 的 日 输 
出 反馈 到 触发 器 的 数据 端 输入 D。 


当然 , 分 频 器 的 输出 可 以 作为 男 一 个 分 频 器 的 Clk 输入 , 并 再 一 次 进行 分 频 。 下 面 是 
三 个 分 频 器 连接 在 一 起 的 示意 图 。 
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下 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


上 图 顶部 的 4 个 信号 变化 规律 如 下 图 所 示 。 


[LTTULIULTUI 


这 里 只 给 出 了 这 幅 图 的 一 部 分 ， 因 为 这 个 电路 会 重复 上 述 过 程 周而复始 地 变化 下 去 。 
在 这 幅 图 中 ， 你 有 没有 发 现 眼 熟 的 东西 呢 ? 


提示 一 下 ， 把 这 些 信号 标 上 0 和 1。 


现在 看 出 来 了 么 ? 试 着 把 这 个 图 顺 时 针 旋 转 90” ， 然 后 读 一 读 每 一 行 的 4 位 数字 ， 
它们 分 别 对 应 了 十 进 制 中 的 0~ 15 中 的 一 个 数 。 
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可 以 看 出 ， 这 个 电路 不 仅仅 具备 了 一 个 计数 功能 。 当 然 ， 如 果 在 这 个 电路 中 添加 更 
多 的 触发 器 ， 其 计数 范围 就 会 更 大 。 在 第 8 章 中 提 到 一 个 顺序 递增 的 二 进 制 序列 ， 每 一 
列 数字 在 0 和 1 之 间 的 变化 频率 是 其 右边 那 一 列 数字 变化 频率 的 一 半 ， 这 个 计数 器 就 是 
模仿 了 这 一 点 。 在 每 一 次 时 钟 信号 的 正 跳 变 时 ， 计 数 器 的 输出 是 增加 的 ， 即 递增 1。 


把 8 个 触发 器 连接 在 一 起 ， 然 后 放 入 一 个 盒子 中 ， 构 成 了 一 个 8 位 计数 器 。 


ck 8 位 行 波 计数 器 
I 
这 个 计数 器 称 为 “8 位 行 波 计数 咒 "， 因 为 每 一 个 触发 器 的 输出 都 是 下 一 个 触发 器 的 
时 钟 输入 。 变 化 是 在 触发 器 中 一 级 一 级 地 顺序 传递 的 ， 最 后 一 级 触发 器 的 变化 必定 会 有 
一 些 延迟 ， 更 先进 的 计数 器 是 “并 行 (同步 ) 计数 器 "， 这 种 计数 器 的 所 有 输出 是 在 同一 
时 刻 改变 的 。 


在 计数 器 中 输出 端 用 Qo ~ Q; 标 记 , 在 最 右边 的 Qo 是 第 一 个 触发 器 的 输出 。 如 果 将 灯 
泡 连 到 这 些 输出 端 上 ， 就 可 以 将 8 位 数字 读 出 来 。 


这 样 一 个 计数 器 的 时 序 图 可 以 将 8 个 输出 分 别 表示 出 来 ， 也 可 以 将 它们 作为 整体 一 
起 表示 出 来 ， 如 下 图 所 示 。 
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证 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


时 钟 信号 的 每 一 个 正 跳 变 发 生 时 ， 一 些 Q 输出 可 能 会 改变 ， 而 另外 一 些 可 能 不 变 ， 
但 总 体 上 来 说 它们 所 表示 的 二 进 制 编码 递增 了 1。 

本 章 前 面 提 到 过 可 以 找到 某 种 方法 来 确定 振荡 器 频率 ,现在 已 经 找到 这 种 方法 了 。 
如 果 把 一 个 振荡 器 连接 到 8 位 计数 器 的 时 钟 输入 端 上 ， 那 么 这 个 计数 器 会 显示 出 振荡 器 
经 过 的 循环 次 数 。 当 计数 器 总 数 达到 11111111 ( 十进制 的 255 )， 它 又 返回 为 00000000。 
使 用 计数 器 确定 振荡 器 频率 的 最 简单 的 方法 就 是 把 计数 器 的 8 个 输出 端 分 别 接 到 8 只 灯 
泡 上 。 当 所 有 的 输出 都 是 0 时 ( 即 所 有 灯泡 都 是 熄灭 的 )， 启 动 一 个 秒表 计时 ; 当 所 有 灯 
泡 都 点 亮 时 ， 停 止 秒表 计时 。 这 就 是 振荡 器 循环 256 次 所 需要 的 时 间 。 假 设 这 个 时 间 为 
10s， 则 振荡 器 的 频率 是 256 -10， 即 25.6 Hz。 

随 着 触发 器 功能 的 增加 ， 它 的 结构 也 变 得 更 加 复杂 ， 下 面 给 出 了 一 个 带 预 置 和 清 零 
功能 的 边沿 型 DD 触发 器 。 


清 零 


通常 情况 下 ， 预 置 和 清 零 信号 输入 会 覆盖 时 钟 和 数据 端 输入 ， 且 两 个 输入 都 为 0， 当 
预 置信 号 为 1 时 ，Q 变 为 1，Q 变 为 0。 当 清 零 信号 为 1，Q 变 为 0，Q 变 为 1 ( 同 R-S 
触发 器 中 的 S 和 及 输入 端 一 样 ， 预 置 和 清 零 信 号 不 能 同时 为 1 )。 除 此 之 外 ， 该 触发 器 工 
作 原 理 是 和 普通 边沿 D 触发 器 是 一 样 的 。 
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现在 ,我 们 已 经 懂得 如 何 使 用 继电器 来 做 加 法 、 减 法 和 计数 了 ， 这 是 一 件 很 有 成 就 
感 的 事情 ， 因 为 我 们 使 用 的 硬件 是 100 多 年 前 就 存在 的 东西 。 我 们 还 有 更 多 未 知 领域 要 


去 探索 ， 请 稍 事 休 息 ， 停 止 ， 


吧 。 


内 考 那些 构造 方面 的 问题 ， 


回 过 头 再 来 看 看 数字 方面 的 问题 
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字 忆 与 十 六 进 制 


通过 对 上 一 章 中 两 类 改进 加 法 机 的 剖析 , 我 们 学 习 了 数据 路 径 ( Data Path ) 这 个 概念 。 
纵 观 整个 电路 的 脉络 ,每 8 个 比特 流 为 一 组 ， 如 泼 漏 溪流 般 在 器 件 与 器 件 之 间 流 动 。 其 
实 ， 这 8 位 比特 流 就 是 加 法 器 、 锁 存 器 以 及 数据 选择 器 的 输入 形式 ， 同 时 它 也 是 这 些 器 
件 单元 的 输出 形式 。 这 8 位 的 比特 流 可 以 用 开关 的 不 同 状态 组 合 所 定义 ， 而 且 可 以 用 灯 
泡 的 亮 灭 来 显示 。 这 样 一 来 ， 这 些 电路 中 数据 路 径 的 位 宽 ( bits wide ) 就 是 8。 为 什么 我 
们 要 把 它 定 义 为 “8” 位 呢 ? 为 什么 没有 定义 为 6 位 、7 位 、9 位 或 10 位 呢 ? 


要 想 用 偷懒 的 方式 回答 上 面 这 个 问题 也 很 简单 ， 答 案 就 是 这 些 加 法 机 都 是 对 第 12 章 
中 原始 加 法 机 的 改进 ， 而 它 所 “流传 ”下 来 的 位 宽 恰 好 就 是 8 位 。 但 是 追根 究 底 ， 原 始 
加 法 机 偏偏 是 8 位 其 实 没 有 什么 特别 的 原因 。 只 不 过 在 每 次 使 用 8 位 位 宽 时 ， 一 切 工作 
都 显得 非常 方便 种 优雅 的 比特 化 ( biteful ) 的 比特 流 。 或 许 大 家 已 经 感觉 到 我 在 极 
力 隐 螨 一 些 东 西 ， 无 法 否认 ， 其 实 我 心中 一 直 都 很 清楚 (或 许 你 也 知道 ): 8 比特 代表 一 
个 字 节 (byte )。 


字 节 这 个 词 最 早起 源 于 1956 年 前 后 ， 由 BM 公司 提出 。 最 早 的 拼写 方式 是 bite, 但 
为 了 避免 与 bit 混淆 用 y 代替 了 i。 兽 几何 时 ， 字 节 仅 表示 某 一 数据 路 径 上 的 位 数 ， 直 到 
20 世纪 60 年 代 中 时 ,在 IBM 的 360 系统 的 发 展 下 (一 种 大 规模 复杂 的 商用 计算 机 )， 字 
节 这 个 词 逐渐 开始 用 来 表示 一 组 8 比特 数据 。 
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由 于 有 8 位 ， 一 个 字 节 的 取 值 范围 为 00000000 到 11111111。 相 应 地 ， 它 还 可 以 表示 
成 为 0~255 之 间 的 正 整 数 ， 如 果 将 一 个 数 的 补 码 作为 其 相对 应 的 负数 ， 那 么 一 个 字 节 可 
以 表示 在 -128 ~ 127 范围 内 的 正 、 负 整数 。 一 个 给 定 的 字 节 可 以 代表 2， 即 256 种 不 同事 
物 中 的 一 个 。 


让 我 们 再 来 看 看 “8” 这 个 数字 ， 当 8 作为 比特 流 的 一 种 尺度 ， 它 的 确 表现 出 了 非常 
完美 的 特质 。 字 节 在 很 多 方面 都 比 单独 的 比特 更 胜 一 筹 。IBM 采用 字 节 有 一 个 很 重要 的 
原因 ， 就 是 这 样 一 来 数字 就 可 以 按照 BCD 形式 (第 23 章 中 将 会 讲述 ) 方便 地 保存 。 在 
本 章 随 后 的 讲述 中 ， 我 们 会 发 现 凑巧 的 是 : 全 世界 大 部 分 书面 语言 (除了 中 文 、 日 文 以 
及 韩文 中 使 用 的 象形 文字 体系 ) 的 基本 字符 数 都 少 于 256, 所 以 字 节 是 一 种 理想 的 保存 文 
本 的 手段 。 字 节 同 样 适合 表 示 黑 白 图 像 中 的 灰 度 值 ,这 是 由 于 肉眼 能 区 分 的 灰 度 约 为 256 
种 。 当 一 个 字 节 无 法 表示 所 有 信息 〈 如 刚 提 到 的 中 文 、 日 文 以 及 韩文 中 使 用 的 象形 文字 
体系 等 ), 我 们 只 需 采用 两 个 字 节 一 一 就 可 以 表示 2“ 也 就 是 65536 个 不 同 的 物体 一 一 这 也 
是 一 种 很 好 的 解决 方案 。 


字 节 的 一 半 一 一 即 4 比特 一 一 我 们 称 之 为 半 字 节 (nibble， 也 可 拼写 成 nybble ), 在 计 
算 机 这 个 领域 ， 它 并 不 像 字 节 那 样 经 常 使 用 。 

由 于 字 节 在 计算 机 内 部 出 现 的 频率 较 高 ， 如 果 可 以 使 用 一 种 简洁 的 方式 将 它 的 内 在 
含义 准确 表达 出 来 ,将 会 为 我 们 带 来 很 多 方便 。 假如 一 个 8 位 二 进 制 数 表示 为 10110110， 
这 种 表达 方式 自然 而 又 直观 ， 但 它 还 不 够 简洁 。 


我 们 完全 可 以 采用 十 进 制 表示 法 来 表示 字 节 ， 但 从 二 进 制 转换 到 十 进 制 需要 进行 一 
系列 计算 一 一 计算 方法 并 不 复杂 , 但 是 比较 麻烦 。 我 曾 在 第 8 章 曾 介绍 过 一 种 直观 的 计算 
方法 。 因 为 每 一 位 二 进 制 数 对 应 着 2 的 不 同 窜 ， 因 此 我 们 可 以 把 二 进 制 数 写 到 第 一 行 ， 
在 底下 写 出 每 一 位 二 进 制 数 对 应 的 2 的 乘 方 数 ， 然 后 采用 “ 列 相 乘 、 行 相 加 ”就 可 以 得 
到 对 应 的 十 进 制 数 。 下 图 表示 了 10110110 的 转换 过 程 。 
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把 十 进 制 数 转换 为 二 进 制 数 就 需要 一 点 点 技巧 了 。 我 们 可 以 用 这 个 十 进 制 数 不 断 除 
以 递减 排列 的 2 的 究 ， 每 除 一 次 得 到 的 商 就 是 所 要 求 的 二 进 制 数 中 的 一 位 ， 而 余数 成 为 
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EF 


下 一 次 运算 的 除数 ， 它 的 作用 是 除 以 下 一 个 较 小 一 点 的 2 的 竹 。 下 图 表示 了 十 进 制 数 182 
转换 成 二 进 制 形式 的 过 程 。 
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第 8 章 对 这 种 计算 方法 有 更 详细 的 描述 。 不 过 ， 在 十进制 数 和 二 进 制 数 之 问 进行 转 
换 还 需 用 到 一 些 工 具 ， 例 如 要 借助 笔 和 纸 进行 一 系列 演算 。 


第 8 章 中 我 们 还 学 到 了 八进制 数 ， 也 称 为 八进制 数字 系统 。 这 种 系统 仅 使 用 到 了 数 


字 0、1、2、3、4、5、6 还 有 7。 八 进 制 数 和 二 进 制 数 之 间 的 转换 简洁 方便 ， 只 要 记 住 0~ 
7 这 8 个 数字 所 对 应 的 3 位 二 进 制 数 即 可 。 下 面 这 张 表 就 表示 了 这 种 对 应 关系 。 
Ee 
| 
一 oo i 
一 oo 
| 
\ 


假如 要 把 一 个 二 进 制 数 (如 10110110 ) 转化 为 8 进 制 ， 可 以 从 最 右 端 的 数字 开始 。 
每 3 比特 看 做 一 组 ， 这 样 每 组 便 对 应 着 一 个 八进制 数 : 
19118119 
2 & 6 
10110110 这 个 字 节 很 容易 就 表示 为 八进制 数 266。 这 种 方法 简洁 明了 , 八进制 用 来 表 
示 字 节 不 失 为 一 个 好 方法 。 但 还 是 有 那么 一 点 美中不足 。 
字 节 可 以 表示 的 二 进 制 数 的 范围 为 00000000 ~ 11111111, 如 果 采 用 八进制 表示 , 那么 
相对 应 的 范围 也 随 之 变 成 了 000 ~ 377。 仔 细 分 析 下 先前 的 例子 ， 我 们 从 右 到 左 把 3 位 二 
进 制 数 对 应 于 中 间 以 及 最 靠 右 的 八进制 数 ， 而 最 靠 左 的 八进制 数 却 是 由 2 位 二 进 制 数 对 
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15 字 节 与 十 六 进 制 了 一 


4 
! 
i 


应 的 。 如 果 我 们 将 16 位 二 进 制 数 直接 表示 为 八进制 会 得 到 如 下 结果 : 
811801111000193 


0 
3 0 3 


如 果 我 们 把 这 个 16 位 二 进 制 数 平分 为 两 个 字 节 并 将 其 分 别 表示 为 八进制 数 会 得 到 如 
下 所 示 的 不 同 结果 : 


1861188611 11908181 
Da I 
2 6 3 3 0 5 


为 了 使 多 字 节 值 能 和 分 开 表示 的 单字 节 值 取得 一 致 ， 我 们 需要 一 种 可 以 等 分 单个 字 
节 的 系统 ， 按 照 这 种 思想 ， 我 们 可 以 把 每 个 字 节 等 分 成 4 组 , 每 组 2 比特 (基于 4 的 计 
数 系统 ) 还 可 以 等 分 为 2 组 , 每 组 4 比特 (基于 16 的 计数 系统 )。 


基于 16 的 计数 系统 (Base 16 )， 对 于 我 们 而 言 是 一 种 全 新 的 系统 。 基 于 16 的 计数 系 
统 也 被 称 为 十 六 进 制 (hexadecimal )， 这 个 单词 很 容易 让 我 们 产生 混淆 。 这 是 因为 很 多 以 
hexa- 为 前 缀 的 单词 (比如 Hexagon， Hexapod 以 及 Hexameter ) 都 会 与 6 或 多 或 少 有 些 
联系 。 而 hexadecimal 这 个 词 却 偏偏 代表 了 16 ( Sixteen ) 这 个 含义 。 虽 然 在 《微软 出 版 物 
风格 与 技术 手册 The Microsoft Manual of Style for Technical Publications ) 中 明确 说 明 “请 
勿 将 十 六 进 制 缩写 为 hex”, 但 包括 我 在 内 的 绝 大 多 数 人 还 总 是 在 不 经 意 间 使 用 这 种 缩写 。 


十 六 进 制 还 有 其 他 -一 些 特别 之 处 。 比 如 在 十 进 制 中 ， 我 们 通常 可 以 用 下 面 这 种 方式 
计数 


0123456789101112... 
我 们 仔细 回忆 一 下 在 八进制 中 ，8 和 9 这 两 个 数字 是 不 需要 的 ， 就 像 下 面 这 样 : 


01234567 101112... 
同 理 ， 四 进 制 计数 中 我 们 也 不 需要 4、5、6、7 这 些 数字 ， 就 像 下 面 这 样 ; 


0123101112.. 
在 二 进 制 中 ， 这 一 切 变 得 更 加 简单 ， 我 们 所 需要 的 只 有 0 和 1: 
| 01 10 14 100... 
十 六 进 制 计 数 和 上 面 所 讲 的 这 一 系列 情况 是 完全 不 同 的 ， 它 需要 比 十 进 制 更 多 的 数 
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人 
字 来 计数 。 十 六 进 制 的 计数 过 程 将 会 是 下 面 这 种 形式 ， 


上 图 中 10( 准确 地 来 说 是 一 个 1 紧 挨 着 一 个 0 ) 这 个 数字 代表 的 准确 含义 实际 上 应 该 是 
十 进 制 中 的 16。 图 中 的 问号 表明 我 们 还 需要 6 个 符号 来 完整 表示 十 六 进 制 系统 。 这 些 符 
号 究竟 是 什么 ? 它们 出 于 何 处 ? 仔细 想 想 ， 原 有 的 计数 系统 中 的 符号 都 有 自己 的 唯一 身 
份 ， 所 以 应 该 而 且 必 须 引 入 新 的 符号 。 寻 找 6 个 新 符号 对 我 们 来 说 是 小 菜 一 碟 ， 例 如 下 
面 这 几 个 符号 : 


/Cw 国 
CP Ww ~ 


不 像 我 们 所 使 用 的 大 多 数 数 字符 号 ， 上 面 列 出 的 每 个 符号 都 很 容易 识 记 ， 而 且 其 背后 都 
隐 含 着 实际 数字 意义 ， 这 种 形象 的 符号 使 得 它们 便于 记忆 。 比 如 这 个 10 加 仑 的 牛仔 幅 、 
一 个 橄榄 球 (11 个 人 组 成 一 支 柑 模 球 队 入 一 打 (12 个 ) 面包 圈 、 一 只 黑 猫 (使 人 们 想起 
不 吉利 的 13 )、 一 轮 满月 (一 般 出 现在 后 弦 月 14 天 之 后 的 夜晚 )， 一 把 已 首 让 人 们 联想 到 
凯撒 大帝 〈 Julius Caesar ) 在 三 月 的 月 中 (第 15 日 ) 被 刺杀 。 


两 个 十 六 进 制 数 可 以 完整 地 代表 一 个 字 节 。 这 也 意 昧 着 一 个 十 六 进 制 数 恰好 由 4 位 
二 进 制 数 组 成 ， 即 半 字 节 。 下 面 这 张 表 描 述 了 如 何在 二 进 制 、 十 六 进 制 、 十 进 制 数 之 间 
进行 转换 。 


二 进 制 | 十 六 进 制 ”| 十 进 制 | 二 进 制 十 六 进 制 。 | 十 进 制 

| oo00 0 i 0 1000 8 | 
0001 1 4 9 

| 9010 2 2 ‘10 
0011 3 3 4 
0100 4 4 | 32 

| oro 5 5 13 
0110 后 6 4 
0111 7 7 15 
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hab 


证 我 们 再 来 看 看 如 何 把 字 节 10110110 转换 成 十 六 进 制 。 


10110110 
让 
i 6 


无 论 是 多 字 节 还 是 单字 节 ， 我 们 都 可 以 进行 转换 。 
1 


Ey 
二 5 


i 


i 


一 个 字 节 能 日 只 能 由 一 对 十 六 进 制 数 来 表示 。 


i110118 i1006181 


ed 


只 可 惜 (或 许 你 也 松 了 口气 ) 我 们 不 打算 用 橄 槛 球 或 一 打 面 包 圈 来 表示 十 六 进 制 数 。 


虽然 这 种 方案 完全 可 行 ， 但 它 不 是 很 方便 也 不 够 1 


十 六 进 制 中 缺少 的 6 个 符号 由 


6 个 拉丁 字母 来 表示 ， 就 像 下 面 这 样 : 


E 规 ， 有 时 还 会 让 人 感到 迷惑 。 事 实 上 


O1234567 89ABCDEF 10141 42... 


下 面 这 张 表 描 述 了 正规 的 二 进 制 、 十 六 进 制 、 


十 进 制 转换 的 过 程 。 


QI01 


十 进 制 


D110 
O11 


1000 
1001 


13 
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下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


这 样 一 来 字 节 10110110 就 可 以 表示 为 十 六 进 制 的 B6 ,而 不 用 画 一 个 橄榄 球 那么 麻烦 。 
我 们 再 回忆 回忆 前 面 的 章节 ， 下 面 举 一 个 完整 的 进 制 转 换 的 例子 ( 用 下 标 代 表 进 制 )， 比 
如 : 


10110110rwo (10110110, ) 
它 的 四 进 制 形式 表示 为 : 
2312rour (23124) 
它 的 八进制 形式 表示 为 : 
266errar ( 266s ) 
它 的 十 进 制 形式 表示 为 : 
1827ex (18210) 
与 此 类 似 ， 它 的 十 六 进 制 形式 可 以 表示 为 : 


B6sprgen ( B61 ) 


但 是 这 种 写法 有 点 累 歼 ， 幸 好 还 有 几 种 表达 十 六 进 制 数 通 用 方法 。 你 还 可 以 用 如 下 方法 
表示 : 
B6Hex 


在 本 书 中 将 使 用 一 种 更 加 简洁 实用 的 方法 ， 那 就 是 用 一 个 小 写 的 h 紧 跟 在 数字 后 边 
表示 这 个 数 是 以 十 六 进 制 表示 的 ， 就 像 这 样 : 


B6h 


通过 分 析 可 以 得 到 十 六 进 制 数 的 每 一 位 代表 16 的 不 同 整数 曙 的 倍数 ， 如 下 图 所 示 。 


人 
16 的 信 数 


256 的 倍数 
4096 的 信 数 


65, 536 的 信 数 
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15 ” 字 节 与 十 六 进 制 下 一 
| 


六 进 制 数 9A48Ch 可 以 表示 为 如 下 形式 : 


9A48Ch = 9 x 10000h + 
Ax1000h+ 
4 Xx 100hb+ 
8 x 10h 十 
Cx1h 


这 个 数 用 16 的 乘 方 表示 可 以 写 为 : 


9A48Ch =9x16°+ 
Ax16+ 
4X16+ 
8x16 + 
Cx16" 


也 可 以 将 16 的 寡 进 一 步 展开 ， 写 为 如 下 形式 : 


9A48Ch = 9 x 65,536 十 
Ax4096+ 
4X256 十 
8 Xx 16 十 
CXx1 


我 们 可 以 仔细 想 想 ， 如 果 只 把 一 个 数字 (比如 9，A, 4,， 8 和 C 中 的 任何 一 个 ) 单独 
列举 出 来 ， 而 且 不 使 用 任何 下 标 来 指明 其 进 制 数 ， 这 种 做 法 并 不 会 产生 二 义 性 。 无 论 在 


十 进 制 还 是 十 六 进 制 下 , 一 个 单独 的 9 仅 代 表 9; 而 A 的 出 现 也 说 明了 它 本 身 是 一 个 十 六 
进 制 数 一 等 价 于 十 进 制 中 的 10。 


我 们 可 以 拿 起 笔 和 纸 进 行 演算 了 ， 把 十 六 进 制 数 转换 成 十 进 制 数 : 


9A48Ch = 9 x 65,536 十 
10 x 4096 + 
4X256 十 
8x16+ 
12x1 


运算 的 最 后 结果 是 631,948。 这 就 是 一 个 十 六 进 制 数 转换 成 为 十 进 制 数 的 完整 过 程 。 
下 面 给 出 了 一 种 模板 ， 它 可 以 帮助 我 们 把 4 位 十 六 进 制 转换 成 为 十 进 制 。 
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} 


下 面 我 们 来 看 一 个 例子 ， 把 79ACh 转化 成 为 十 进 制 数 。 需 要 牢记 在 心 的 就 是 A 和 C 
分 别 代 表 10 和 12。 


一 -一 省 本 
e+ [0] + = 


十 进 制 数 转换 为 十 六 进 制 数 通常 涉及 除法 运算 。 我 们 知道 ,小 于 或 等 于 255 的 数 用 1 
个 字 节 就 足以 表示 ， 也 就 是 两 个 十 六 进 制 数 。 如 何 来 求 出 这 两 个 数 呢 ? 通常 可 以 用 这 个 
数 除 以 16， 分 别 得 到 商 和 余数 ， 商 作为 结果 保留 ， 而 余数 则 作为 下 次 运算 的 除数 。 我 们 
举 一 个 先前 讲 过 的 例子 来 进一步 阐述 运算 法 则 : 十 进 制 数 182， 除 以 16， 商 为 11 (在 十 
六 进 制 中 表示 为 B )， 余 数 为 6， 所 以 它 的 十 六 进 制 为 B6h。 


如 果 被 转化 的 十 进 制 数 小 于 65,536， 那 么 就 可 以 使 用 少 于 4 位 的 十 六 进 制 数 来 表示 。 
下 面 给 出 一 个 十 进 制 向 十 六 进 制 数 转化 的 一 个 模板 。 
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一 396 5 +16 
= Ea EE 
使 用 时 首先 把 十 进 制 写 到 左上 角 的 方 框 里 。 这 个 方 框 代表 着 第 一 个 被 除数 ， 然 后 除 
以 第 一 个 除数 4096， 得 到 的 商 放 到 被 除数 所 对 应 的 下 面 的 方 框 里 ， 而 将 余数 放 到 被 除数 
右边 的 方 框 里 。 这 时 将 余数 作为 新 的 被 除数 去 除 以 256。 利 用 这 个 规则 ,通过 反复 和 迭代 就 
可 以 得 到 最 终结 果 。 下面 这 幅 图 向 我 们 展示 了 十 进 制 数 31,148 转换 成 十 六 进 制 数 的 过 程 。 


~ 


和 EE : 
[Lz] 
显而易见 ,十进制 数 的 10 和 12 代表 着 十 六 进 制 中 的 A 和 C， 计 算得 到 的 最 后 结 
就 是 79ACh。 
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: 


这 个 方法 存在 一 个 小 小 的 问题 ， 那 就 是 如 果 使 用 计算 器 帮助 你 进行 除法 运算 ， 它 不 
会 显示 每 步 运算 得 到 的 余数 是 多 少 。 如 果 让 计算 器 去 运算 31,148 除 以 4096， 它 的 屏幕 上 
只 会 出 现 7.6044921875。 我 们 可 以 用 倒 推 的 方法 计算 余数 , 用 4096 乘 以 7( 得 到 28,672 )， 
从 31,148 中 减 去 它 , 这 是 一 种 办 法 。 也 可 以 用 4096 乘 以 0.6044921875， 也 就 是 计算 器 运 
算 结果 的 小 数 部 分 ( 现在 市 面 上 很 多 计算 器 已 经 具备 了 十 进 制 和 十 六 进 制 数 之 间 的 转换 
功能 )。 

还 有 一 种 转换 小 于 65,535 的 十 六 进 制 数 的 方法 ， 首 先 我 们 把 原 数 通过 除 以 256 的 方 
式 将 其 分 为 两 个 字 节 。 接 下 来 对 于 每 个 字 节 ， 再 分 别 除 以 16。 下 图 是 运算 过 程 使 用 到 的 
模板 。 


我 们 采用 自 顶 向 下 的 方式 。 每 一 次 除法 完成 后 ， 就 将 其 得 到 的 商 放 入 除数 左下 方 的 
方 框 里 ， 而 余数 进入 右边 的 方 框 里 。 下 图 举例 说 明了 十 进 制 数 51,966 的 转换 过 程 。 


En 


256 


Er EY 


二 站 -16 
回回 加 加 
最 后 我 们 得 到 了 四 个 1 位 的 十 六 进 制 数字 ， 其 十 进 制 值 分 别 是 12、10、15 和 14， 转 
换 过 来 就 是 CAFE， 无 论 怎么 看 它 都 更 像 一 个 单词 ， 很 难 想象 它 其 实 是 一 个 数字 (我 想 应 
该 没 人 愿意 点 一 杯 叫 做 56,495 的 东西 ， 然 后 把 它 当 作 咖 啡 喝 下 去 吧 包 


对 于 每 种 计数 系统 ， 我 们 都 可 以 描绘 出 相应 的 操作 运算 表 ， 下 面 是 十 六 进 制 的 加 法 
运算 表 。 
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一 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


5| 5|7| 
回回 在 
了 | 
ss la 
回 四 加 
四 加 四 

本 

四 


一 


SE 

lele ol 
四 面 加 对 加 
四 下 四 加 四 四 
ple | le | sla | 
clolefrelolr [esle Ds) 
olelre lol fadsie ls 
回回 四 团 固 国 回 国 轴 加 
加 四面 四 因 因 国 四 加 加 
四国 四国 轨 男 国 加 四 四 
国 因 国 四 天 因 加 加 四 四 
因 国 固 国 四 国 面 回国 轨 加 加 
lole [ref hall ss sls [af 
ede lo [ahs ier [lle 
[lolelalslslzlellepalcholes 


使 用 这 张 表 可 以 方便 地 仿照 一 般 的 加 法 运算 来 对 十 六 进 制 数 进行 加 运算 ， 如 下 例 所 


A 


目 四 加 回回 吕 可 回电 可 中 


古国 轨 遇 多 国 国 医 男 四 


4A3378E2 
+ 877AB982 
D1AE3264 
回忆 一 下 第 13 章 的 内 容 ,我 们 讨论 过 可 以 用 一 个 2 的 补 数 来 表示 与 其 相对 应 的 负数 。 
如 果 我 们 处 理 的 是 带 符号 的 8 位 二 进 制 数 ,那么 所 有 负数 的 最 高 位 都 为 1。 在 十 六 进 制 系 
统 中 ， 最 高 位 为 8、9、A、B、C、D、E 或 的 两 位 带 符号 数 都 是 负数 ， 因 为 这 些 十 六 进 
制 数 对 应 的 二 进 制 数 的 最 高 位 为 1。 例 如 99h 可 以 表示 无 符号 的 十 进 制 数 153 ( 你 必须 清 
楚 它 是 单字 节 的 无 符号 数 )， 也 可 以 表示 十 进 制 的 -103 ( 这 时 它 被 看 做 有 符号 数 )。 
奇妙 的 是 ，99h 这 个 十 六 进 制 字 节 从 某 种 意义 上 来 讲 ， 也 代表 着 十 进 制 的 991 我 们 
都 非常 想 知道 原因 ， 不 过 这 种 说 法 似乎 和 先前 所 学 到 的 所 有 东西 相抵 触 。 我 会 在 第 23 章 
中 进行 详细 解释 。 但 在 此 之 前 ， 我 们 必须 先 讨论 一 下 存储 器 方面 的 知识 。 
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每 天 清晨 ,我们 将 自己 从 沉睡 中 唤醒 ， 这 时 大 脑 的 空白 会 很 快 被 记忆 填充 。 我 们 立 
刻 会 意识 到 自己 身 在 何方 ， 最 近 做 了 些 什么 事情 ， 有 什么 计划 和 打算 。 有 的 事情 我 们 很 
快 就 能 想起 来 ,但 有 了 时， 我们 大 脑 处 于 失忆 状态 ， 有 那么 几 分 钟 发 现 自己 什么 部 想 不 起 
来 (就 拿 我 来 说 ， 有 时 我 就 是 想 不 起 来 怎么 我 上 床 时 还 穿着 袜子 )， 但 总 的 来 说 ， 我 们 总 
是 能 够 与 自己 的 过 去 保持 足够 的 连续 性 ， 继 续 新 的 生活 ， 展 开 人 生 新 的 一 页 。 


显然 ， 人 类 的 记忆 似乎 没有 什么 规律 。 仔 细 回 想 高 中 的 几何 课 ， 或 许 你 一 下 子 就 能 
想到 是 谁 坐 在 你 前 面 ， 或 许 你 清晰 地 记得 当 老师 讲 到 QED ( quod erat demonstrandum， 证 
明 与 推论 ) 这 个 概念 的 时 候 消 防 演习 开始 了 。 


人 类 的 记忆 也 并 非 能 面面俱到 。 书 面 记录 这 种 技术 的 引入 ， 从 某 种 层面 来 讲 ， 就 是 
为 了 弥补 人 类 记忆 容易 遗漏 这 一 缺陷 。 或 许 在 某 天 夜里 凌晨 三 点 ， 你 从 床上 一 路 而 起 ， 
脑海 中 突然 出 现 某 个 剧本 的 绝妙 灵感 。 你 立刻 抓 起 床 边 提前 预备 的 笔 和 纸 ， 将 它们 全 部 
记 下 防止 遗忘 ， 然 后 才 安然 入 睡 。 一 觉醒 来 的 清晨 ， 再 次 浏览 这 个 绝妙 的 灵感 ， 一 个 新 
的 剧本 构想 路 然 纸 上 ( 剧本 的 内 容 就 是 “一 次 多 逅 ， 汽 车 追尾 与 爆炸 ”? 仅 此 而 已 吗 ? ) 
或 许 远 不 如 此 。 


我 们 总 是 将 需要 的 记 住 的 内 容 事先 记 下 来 ， 在 需要 时 拿 出 来 阅读 ， 习 惯 于 将 可 能 用 


和 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


到 的 事物 先 存 起 来 ， 在 需要 时 将 它们 取出 。 从 技术 角度 来 讲 ， 这 个 过 程 称 为 先 存 储 后 访 
间 。 存 储 串 的 职责 和 作用 就 在 于 此 ， 它 负责 保障 这 两 个 过 程 之 闻 信 息 完好 无 损 。 我 们 每 
次 存储 信息 都 要 利用 不 同 种 类 的 存储 器 。 比 如 ， 保 存 文本 信息 的 不 二 之 选 就 是 纸张 ， 而 
磁带 则 更 适 于 存储 音乐 和 电影 。 


电报 继电器 (Telegraph Relays ) 一 一 以 一 定形 式 组 织 起 来 构成 逻辑 门 , 然后 再 形成 触 
发 器 一 一 同样 具备 保存 信息 的 能 力 。 在 前 面 章节 中 我 们 讨论 过 ， 一 个 触发 器 可 以 对 1 位 
信息 进行 存储 。 这 样 的 存储 能 力 要 存储 一 大 堆 的 信息 还 远 远 不 够 ， 但 它 却 为 我 们 达到 目 
标 迈 出 了 坚实 的 一 步 。 其 实 知道 了 如 何 存储 1 位 信息 ， 很 容易 就 可 以 想象 出 如 何 存储 2 
位 、3 位 或 更 多 位 信息 。 


在 第 14 章 的 学 习 过 程 中 ,我 们 一 起 讨论 过 由 一 个 反 向 器 、 两 个 与 门 和 两 个 或 非 门 构 
成 的 D 型 电 平 触发 器 ， 如 下 图 所 示 。 


当时 钟 输入 为 1，Q 端 输出 与 数据 端 输 入 保持 一 致 。 但 当时 钟 输入 卡 变 为 0 时 ，Q 端 输 
将 保持 数据 端 最 后 一 次 的 输入 。 除 非 时 钟 输 入 再 次 还 原 为 1, 之 后 的 数据 端 输入 不 会 影响 
输出 。 此 触发 器 的 真 值 表 如 下 。 


在 第 14 章 的 讨论 中 ， 这 种 触发 器 可 以 由 两 种 不 同 特性 的 电路 来 实现 ， 而 在 本 章 我 们 
仪 选择 其 中 一 种 一 一 目的 就 只 是 为 了 保存 1 位 信息 。 为 了 更 加 清楚 地 表述 ， 我 们 给 输入 
和 输出 端 重新 命名 ， 使 其 名 称 与 功能 相符 ， 如 下 图 所 示 。 
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] 
‘ 


数据 输入 


从 结构 上 来 讲 ， 这 套 电路 与 先前 所 学 到 的 是 同一 种 触发 器 ， 只 是 命名 的 方式 不 尽 相 
同 ， 现 在 Q 输出 端 被 称 为 数据 输出 端 (Data Out )， 时 钟 输入 端 (在 第 14 章 叫做 保持 位 ) 
命名 为 写 操作 端 ( Write )。 就 像 信 息 可 以 被 记录 在 纸 上 一 样 ， 写 操作 端的 信号 同样 使 得 数 
据 输 入 (Data In ) 信号 被 写 入 (Written Into )， 也 可 以 称 之 为 被 存储 (stored ) 到 电路 中 。 
一 般 情 况 下 ， 如 果 写 操作 端 为 0， 则 数据 输入 信号 的 状态 对 输出 无 影响 。 而 当 我 们 想 把 数 
据 输 入 信号 存储 在 触发 器 中 时 ， 可 以 把 写 入 信号 应 先 置 1 后 置 为 0。 在 第 14 章 讲 到 过 ， 
这 种 类 型 的 电路 也 被 称 为 锁 存 器 ， 因 为 存储 进去 的 数据 就 好 像 被 锁 住 了 一 样 。 下 面 给 出 
了 1 位 锁 存 器 简化 框图 ， 框 图 未 画 出 其 内 部 结构 中 的 部 件 。 


DI 
DO 
陵 


我 们 很 容易 想到 如 何 把 多 个 1 位 锁 存 器 组 织 成 为 多 位 锁 存 器 ， 所 要 做 的 就 是 把 写 操 
作 端 的 信号 连接 到 系统 中 ， 就 像 下 面 这 样 。 


写 操作 淆 往 入 端 


完 DI Ww Dl 


输出 端 


图 中 显示 的 8 位 锁 存 器 其 输入 和 输出 端 各 有 8 个 。 另 外 还 包括 一 个 写 操作 端 ， 在 非 工 作 
状态 下 一 般 为 0。 如 果 要 把 一 个 8 ee de 首先 要 把 写 操作 端 置 1， 
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一 下 编码 一- 隐匿 在 计算 机 软 硬 件 背后 的 语言 
: 


然后 置 0。 我 们 同样 可 以 把 这 个 锁 存 器 以 框图 的 形式 表现 出 来 ， 就 像 下 面 这 样 。 


| 


Dl; Dis Di Da Di Pb Ph Di 
WwW 8 仓 锁 存 器 


DO BOs DO，DO。DO，Do，DO， Don 


为 了 和 先前 提 到 的 1 位 锁 存 器 保持 一 致 ， 我 们 将 它 可 以 画 成 下 面 这 种 形式 。 


数 扩 铂 入 8 位 锁 丰 器 。 DO I> 数据 输出 
写 操作 端 加 


还 有 另 一 种 方法 集成 8 个 1 位 锁 存 器 ， 但 其 结构 并 不 像 上 面 的 这 样 直 观 。 假 设 我 们 
只 想 用 一 个 数据 输入 和 输出 信号 端 ， 而 且 希 望 锁 存 器 能 将 输入 信号 数据 分 8 次 独立 存储 ， 
这 个 任务 可 以 在 长 达 一 天 内 完成 ， 或 者 可 能 迅速 在 下 一 分 钟 内 搞定 。 最 后 一 项 要 求 就 是 
我 们 还 希望 能 够 通过 观察 数据 输出 信号 端 确定 实际 的 8 位 输出 。 


换 名 话说， 在 这 种 锁 存 器 中 我 们 只 想 存 储 8 个 单独 的 比特 ， 而 不 是 存储 1 个 8 位 二 
进 制 数 。 


为 什么 会 有 这 种 需求 呢 ? 原因 可 能 在 于 仅 有 一 个 灯泡 ! 


我 们 知道 现在 所 需要 的 是 8 个 1 位 锁 存 器 。 先 不 去 考虑 数据 如 何 存储 在 这 些 锁 存 器 
中 ， 把 重点 放 在 如 何 用 一 个 灯泡 来 确定 锁 存 器 的 数据 输出 信号 。 最 简单 的 方法 就 是 把 这 
个 灯泡 依次 连接 到 每 个 锁 存 器 上 ， 分 若干 次 来 测试 各 个 锁 存 器 的 输出 ， 但 是 我 们 要 追求 
更 加 自动 化 的 方法 。 用 开关 来 选择 想 要 检查 的 锁 存 器 是 一 个 好 的 办 法 。 


竟 需 要 多 少 个 开关 才能 解决 问题 呢 ? 我 们 可 以 把 这 个 过 程 进一步 抽象 ， 问 题 变 成 
了 怎 2 8 个 物体 中 选 出 一 个 我 们 想 要 的 ， 我 们 需要 3 个 开关 。 这 是 因为 通过 3 个 开 
关连 通 与 闭合 的 排列 组 合 ， 总 共 可 表示 出 8 个 不 同 的 值 : 000、001、010、011、100、101、 
110 和 111。 


现在 我 们 手头 上 已 有 8 个 1 位 锁 存 器 、3 个 开关 、1 个 灯泡 ， 此 外 在 开关 和 灯泡 之 间 
还 有 另外 一 种 装置 ， 如 下 图 所 示 。 
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这 个 “额外 装置 ”就 是 图 中 的 神秘 盒子 ， 顶部 带 有 8 个 输入 端 ， 左 侧 也 带 有 3 个 输入 端 。 
通过 三 个 开关 的 闭合 和 断 开 ， 对 顶部 的 输入 进行 8 选 1 操作 ， 输 出 结果 被 传递 到 其 底部 
连接 的 灯泡 ， 使 其 发 光 。 


上 图 标注 的 “这 是 什么 装置 ? ”到 底 是 什么 昵 ? 我 们 先前 曾 碰见 过 类 似 的 东西 ， 当 
时 讨论 的 装置 没有 这 人 么 多 的 输入 端 。 这 种 装置 兽 出 现在 第 14 章 中 第 一 个 改进 的 加 法 机 的 
电路 中 。 在 该 电路 中 要 在 一 行 开关 和 一 个 锁 存 器 的 输出 之 间 选 择 一 个 ， 作 为 加 法 器 的 输 
入 ， 当 时 称 其 为 2-1 选择 器 。 而 我 们 现在 所 需要 的 正 是 8-1 数据 选择 器 ( 8-Line-to-1-Line 
Data Selector )。 


8-1 选择 髓 有 8 个 数据 输入 端 (在 其 顶部 )， 以 及 3 个 选择 输入 端 (在 其 左 侧 )。 选择 
输入 端的 功能 就 是 选择 一 个 输入 端 数据 , 然后 使 其 在 输出 端 输出 。 如 果 选 择 输 入 端 为 000， 
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则 将 Do 锁 存 器 的 值 输出 ; 若 选 择 端 为 111, 则 D; 锁 存 器 的 值 将 被 输出 ; 若 选 择 端 为 101， 


则 相应 地 输出 D 的 值 。 系 统 的 真 值 表 如 下 所 示 。 


8-1 选择 器 主要 组 成 部 件 为 : 三 个 反 向 器 、 八 个 4 端口 输入 与 门 、 一 个 8 端 


门 ， 系 统 的 组 织 结构 如 下 图 所 示 。 


上 
| [和 -一 一 一 
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输入 或 


这 个 电路 看 上 去 线路 密布 ， 要 理解 它 是 如 何 工 作 的 ， 最 好 方式 就 是 一 起 来 看 一 个 例 


子 。 假 设 S 初 始 化 为 1，Si 初 始 化 为 0，So 初 始 化 为 1。 从 顶部 姑 


F 始 的 第 6 个 与 门 的 输入 


由 So、S 、S; 组成， 初始 状态 下 它们 全 为 1。 其 余 与 门 的 这 三 项 输入 数据 都 与 第 6 个 与 
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门 不 尽 相同 ,这 使 得 其 余 与 门 输出 全 部 为 0。 若 D; 变 为 0 意味 着 第 6 个 与 门 输出 为 0; 反 
之 第 6 个 与 门 输出 则 为 1。 对 最 右边 的 或 门 也 可 以 按照 同样 的 方式 理解 。 我 们 可 以 总 结 出 
下 面 这 个 结论 : 若 选 择 端 为 101， 则 数据 输出 端 与 Ds 的 输出 保持 一 致 。 


让 我 们 重新 理 一 下 思路 , 想 想 自己 完 竞 要 干什么 。 我 们 的 目的 是 通过 某 种 方式 连接 8 
个 1 位 锁 存 器 ， 使 自己 能 够 从 一 个 输入 信号 端 写 入 数据 ， 还 能 从 一 个 输出 信号 端 鉴 别 出 
数据 。 现 在 我 们 已 经 成 功 地 使 用 了 一 个 8-1 选择 器 对 8 个 锁 存 器 进行 了 选择 操作 , 并 将 村 
应 锁 存 器 的 数据 输出 ， 下 面 是 电路 的 结构 图 。 


Ds DB: D: DBD: Dy, 
8--1 选 择 器 


到 这 里 我 们 只 走 完了 长 征 的 一 半 。 既 然 输出 端 已 经 满足 了 要 求 ， 现 在 把 注意 力 集中 到 输 
入 端 。 

输入 端 包 括 了 数据 输入 信号 及 写 操 作 信号 。 可 以 把 所 有 数据 输入 信号 在 锁 存 器 的 输 
入 端 连 接 在 一 起 。 但 8 个 写 入 信号 是 不 可 以 连 在 一 起 的 ， 因 为 我 们 很 可 能 要 向 每 个 锁 存 
器 依次 写 入 数据 。 除 此 之 外 还 需要 一 个 独立 的 写 入 信号 ， 它 能 被 路 由 到 任意 〈 且 唯一 ) 
的 锁 存 器 上 ， 系 统 的 结构 可 用 下 图 表示 。 
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为 了 能 圆满 完成 任务 , 我 们 需要 另外 一 款 电路 元 件 ， 而 且 这 款 元 件 与 8-1 选择 器 功能 
类 似 ， 但 它 的 作用 正好 相反 。 我 们 所 说 的 正 是 3-8 译 码 器 (3-to-8 Decoder )。 前 面 的 章节 
中 我 们 兽 学 习 过 一 个 简易 的 数据 译 码 器 (Data Decoder ) 一 一 在 第 11 章 中 为 了 选择 喜欢 的 
猪 咪 的 毛色 ， 我 们 把 开关 以 一 定 方式 进行 连接 使 其 具有 选择 功能 。 

3-8 译 码 器 的 输出 端口 共有 8 个 。 在 任何 时 刻 , 译 码 器 只 会 有 一 个 锁 存 器 的 输出 为 1， 
其 余 均 为 0。 每 一 个 输出 端的 结果 都 是 由 So、Si、$: 这 三 个 信号 的 排列 组 合 决定 的 。 而 数 
据 的 输出 和 输入 一 致 ， 如 下 图 所 示 。 
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我 想 再 次 强调 一 遍 : 注意 从 上 往 下 数 的 第 6 个 与 门 ， 它 的 输入 包括 Sh、 S1、S2。 没 
有 任何 一 个 与 门 具有 和 它 相 同 的 三 个 输入 。 在 这 种 情况 下 ， 如 果 选 择 输入 端 为 101， 则 除 
了 0; 要 根据 情况 进行 判定 外 ， 其 余 与 门 输 出 都 为 0。 这 个 时 候 ， 若 数据 端 输 入 为 0， 则 
0; 随 之 输出 为 0; 相应 的 ， 若 数据 端 输入 为 1， 则 0s 输 出 为 1。 译 码 器 的 逻辑 表 可 以 如 下 
表 所 示 。 


Dara 


Data 身 


将 8 个 锁 存 器 加 入 到 电路 就 形成 了 完整 的 系统 。 
地 址 端口 写 操作 油 数据 输入 


数据 端 
3-8 译 码 嚣 


这 DE 区 BE || 六 DL 
DO DO DO 
DD 3 


有 9 


8--1 选 择 器 


输出 冰 
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本 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 


值得 注意 的 是 ， 译 码 器 和 选择 器 具有 相同 的 选择 信号 ， 在 上 图 中 这 三 个 信号 一 起 被 
称 为 地 址 端口 ( Address )。 地 址 的 作用 就 像 我 们 平时 使 用 的 邮箱 号 ， 长 度 为 三 位 的 地 址 决 
定 了 8 个 锁 存 器 中 的 哪 一 个 将 被 引用 。 在 3-8 译 码 器 的 输入 端 , 地 址 起 到 了 决定 哪些 锁 存 
器 可 以 被 写 操作 端的 信号 触发 来 保存 数据 的 作用 。 在 输出 端 〈 图 的 下 半 部 分 )，8-1 选择 
器 通过 地 址 来 选择 8 个 锁 存 器 中 的 一 个 ， 最 后 将 其 输出 。 


这 种 配置 下 的 锁 存 器 在 有 的 资料 中 也 被 称 为 读 / 写 存储 器 (read/write memory )， 但 更 
普遍 的 叫 法 是 随机 访问 存储 器 (Random Access Memory ),， 或 RAM (和 单词 animal 发 普 
类 似 )。 可 以 认为 我 们 讨论 的 这 种 存储 器 是 可 存储 8 个 独立 比特 的 RAM， 它 的 简化 结构 
图 如 下 所 示 。 


一 下 和， 
地 址 一 A 
一 上 2 


数据 输入 ip 8x1 RAM DO| 一 -数据 输出 
写 操 作 油 __|Ww 


上 图 所 示 的 电路 之 所 以 能 够 被 称 为 存储 器 是 因为 它 可 以 保存 信息 。 而 能 够 被 称 为 读 / 
写 存 储 器 是 因为 它 不 仅 可 以 在 每 个 锁 存 器 中 存储 新 的 数据 (可 以 把 这 种 功能 称 为 号 数 
据 )， 而 且 我 们 还 可 以 检查 每 个 锁 存 器 都 保存 了 什么 数据 (可 以 把 这 种 功能 称 为 读数 据 )。 
之 所 以 可 以 被 称 为 随机 访问 存储 器 ， 是 因为 读 写 操作 很 自由 ， 我 们 只 需要 改变 地 址 及 相 
关 的 输入 ， 就 可 以 从 8 个 锁 存 器 中 读 出 或 号 入 需要 的 数据 。 相 比 于 其 他 的 顺序 型 的 存储 
器 一 一 这 种 存储 器 在 使 用 时 有 一 定 的 限制 ， 如 果 想 要 读 取 地 址 为 101 的 数据 ， 必 须 先 把 
地 址 为 100 的 数据 读 取出 来 。 


将 RAM 进行 特殊 的 配置 可 形成 RAM 阵列 ( Array )， 我 们 所 讨论 的 这 种 RAM 阵列 
以 8x1( 读 做 8 对 1) 的 方式 组 织 起 来 。 阵 列 以 1 比特 作为 存储 单位 ， 共 存储 8 个 单位 的 
数据 。 所 以 这 个 RAM 阵列 中 能 存储 的 位 数 等 于 8 与 1 的 乘积 。 
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16 


RAM 阵列 的 组 合 形式 多 种 多 样 。 比 如 我 们 可 以 通过 共享 地 址 的 方式 可 以 把 两 个 8x1 


的 RAM 阵列 连接 起 来 ， 如 下 图 所 示 。 


Bx RAM DO 


数据 输入 3SxtRANM DO 


据 输 出 


数据 输出 


我 们 把 这 两 个 8x1 的 RAM 阵列 的 地 址 和 输出 都 分 别 看 成 一 个 整体 ， 这 样 就 得 到 了 一 个 


8x2 的 RAM 阵列 ， 如 下 图 所 示 。 


1 


地 址 一 | 人 
= 
- 5 DOn 
— DFE 
写 操作 端 lw 


数据 输出 


这 个 RAM 阵列 可 存储 的 二 进 制 数 依然 是 8 个 ， 但 每 个 数 的 位 宽 为 2 位 。 
我 们 还 可 以 把 两 个 8x1 的 RAM 阵列 看 做 是 两 个 锁 存 器 , 使 用 一 个 2-1 选择 器 和 一 个 


1-2 译 码 器 就 可 以 把 它们 按照 单个 锁 存 器 连接 方式 进行 集成 ,下 面 给 出 了 这 种 方案 的 电路 


图 。 
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本 编码 隐匿 在 计算 机 软 硬 件 背后 的 语言 


写 操作 端 。 地 址 ”数据 输入 


Ww AoAlA 


8x1 RAN 8x1 RAM 


DO 


数据 输出 


DI 


“选择 ” 端 之 所 以 连接 到 译 码 器 和 选择 器 ， 主 要 作用 是 在 两 个 8x1 RAM 阵列 中 选择 
一 个 ,本 质 上 它 扮演 了 第 4 根 地 址 线 的 角色 。 因 此 这 种 结构 实质 上 是 一 种 16x1 的 RAM 阵 


列 ， 如 下 图 所 示 。 


0 

地 址 Ai 
A3 16x1 RAM “DO 一 数据 输出 

数据 输入 __JPT 

写 操作 端 __iw 


上 图 所 示 的 RAM 阵列 存储 容量 为 16 个 单位 ， 每 个 单位 占 1 位 。 
RAM 阵列 的 存储 容量 与 其 地 址 输入 端的 数量 有 直接 的 联系 。 在 没有 地 址 输入 端的 情 


况 下 (只 有 1 位 锁 存 器 和 8 位 锁 存 器 的 情况 )， 只 能 存储 1 个 
址 输入 端 时 ， 可 以 存储 2 个 单位 的 数据 ; 有 两 个 地 址 输入 端 时 


位 的 数据 ， 当 存在 1 个 地 
|， 可 以 存储 4 个 单位 的 数 


据 ; 有 3 个 地 址 输入 端 时 ， 可 以 存储 8 个 单位 的 数据 ;有 4 个 地 址 输入 端 时 ， 可 以 存储 
16 个 单位 的 数据 。 我 们 可 以 把 它们 之 间 的 关系 归纳 成 如 下 等 式 : 
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16 存储 器 组 织 下 


RAM 阵列 的 存储 容量 一 2 ~ 人 
前 面 已 经 向 大 家 演示 了 怎么 搭建 小 型 RAM 阵列 , 你 可 能 会 问 : 为 什么 不 搭建 一 个 大 


规模 的 RAM 阵列 呢 ? 就 像 下 面 这 样 。 
地 址 > Acddr 
数据 输入 DO | 据 输出 
DI 1024x8 下 
写 操作 消 “jw 


上 图 所 示 的 RAM 阵列 可 存储 8192 个 比特 的 信息 ， 每 8 个 比特 为 一 组 ， 共 分 为 1024 
个 组 。 因 为 2 的 10 次 方 恰 好 是 1024， 所 以 地 址 端 10 个 输入 端口 。 电 路 还 包括 8 位 
的 数据 输入 端 和 8 位 的 数据 输出 端 。 


从 专业 的 角度 来 讲 ， 这 个 RAM 阵列 的 存储 容量 为 1024 个 字 节 。 就 好 比 一 个 邮局 放 
置 了 1024 个 邮箱 ， 而 每 个 邮箱 里 面 都 可 以 存放 1 字 节 大 小 的 邮件 (希望 不 是 垃圾 邮件 )。 


1024 字 节 通常 简称 为 1 干 字 节 ( kilobyte ), 1K 这 种 称呼 不 可 避免 地 要 引起 许多 混淆 。 
其 中 它 的 前 缀 kilo ( 源 于 希腊 文 khilioi， 意 思 为 1000 )， 经 常 在 公制 系统 中 用 到 。 比 如 1 
干 克 ( kilogram ) 代表 着 1000 克 ( grams ); 1 干 米 (kilometer ) 代 表 着 1000 米 (meter )。 
有 所 不 同 的 是 ， 这 里 所 说 的 1 千 字 节 却 代表 着 1024 个 字 节 一 一 并 非 1000 个 字 节 。 


它们 之 间 不 同 的 根本 原因 在 于 公制 系统 是 基于 10 的 寡 的 计数 系统 ， 而 计算 机 采用 的 
是 基于 2 的 帘 的 计数 系统 ， 它 们 之 间 没 有 交集 。 比 如 10 的 医 为 10、100、1000、10000、 
100000 等 ， 而 2 的 窜 为 2、4、8、16、32、64 等 。 我 们 可 以 证 明 不 存在 一 对 整数 a 和 b 

. 使 得 10 的 a 次 寡 与 2 的 b 次 寡 相 等 。 


但 是 偶尔 也 会 碰见 非常 接近 的 数字 。 事 实 的 确 如 此 ，1000 十 分 接近 1024， 用 数学 化 
的 描述 方法 可 以 称 这 种 关系 为 “ 约 等 于 " ， 这 样 我 们 可 以 得 到 相应 的 数学 表达 式 : 


210 ~ 10 


这 个 表达 式 并 非 空 六 来 风 ， 它 真正 的 意义 在 于 表明 2 的 某 次 医 和 10 的 某 次 窜 几 平 相 
等 。 我 们 利用 这 一 巧合 可 以 很 方便 地 把 1024 个 字 节 的 存储 空间 用 1 干 字 节 来 表示 。 


209 # 


本 编码 一 隐匿 在 计算 机 软 硕 件 青 后 的 语言 


千 字 节 可 以 简写 为 KB。 这 样 我 们 可 以 说 前 面 所 讲 过 的 那个 RAM 阵列 存储 能 力 为 
1024 个 字 节 ， 也 可 以 说 成 是 1KB。 


绝 不 能 认为 1KB 的 RAM 阵列 的 存储 能 力 为 1000 字 节 , 它 实际 上 是 大 于 1000 字 节 ， 
是 1024 个 字 节 ， 为 了 准确 而 清晰 地 表达 你 脑海 中 的 数据 ， 我 们 可 以 使 用 “1 KB”” 或 “1 
干 字 节 ”这 两 种 通用 的 表述 方式 。 


存储 容量 为 1KB 的 存储 系统 由 8 个 数据 输入 端 、8 个 数据 输出 端 和 10 个 地 址 输入 端 
所 组 成 。 由 于 这 些 字 节 是 由 10 个 地 址 输入 端 来 标识 和 访问 的 ， 所 以 这 种 RAM 阵列 存储 
容量 为 2 "个 字 节 。 如 果 我 们 再 加 上 一 条 地 址 线 ， 它 的 存储 容量 将 变 成 原来 的 两 倍 。 下 面 
的 公式 表示 了 存储 容量 的 翻 倍 的 过 程 。 


1KB=1024B=20B=10B 

2 KB=2048 B=21B 

4KB=4096 B=2°*B 

8 KB=8192B=2*B 

16 KB = 16,384 B=2"B 

32 KB =32.768B=25B 

64 KB =65,536 B=2'B 

128 KB= 131,072 B=2”B 

256 KB =262,144 B=2*B 

512 KB = 524,288 B=2”B 

1,024 KB = 1,048,576 B= 2 B10°B 
请 注意 最 左 侧 一 排 的 数字 也 以 2 的 寡 的 顺序 逐步 递增 。 

我 们 把 1024 个 字 节 简化 成 为 了 1 KB， 相 同 的 逻辑 ， 我 们 把 1024 KB 统称 为 1 兆 字 


节 (megabyte， 希腊 文中 的 mega 意味 着 宏大 )， 兆 字 节 通 常 缩写 为 MB。 下 面 这 个 例子 表 
示 了 泡 字 节 为 单位 的 存储 容量 翻 倍 的 过 程 。 


1 MB= 1.048.576B=220B=105B 
2MB=2,097,152 B=2B 
4MB=4,194,304 B=22B 
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8 MB = 8,388,608 B= 22 8 

16 MB =16,777,216 B=228 

32MB =33,554,432B=23B 

64 MB = 67,108,864 B = 2*B 

128 MB = 134,217,728 B =27 8 

256 MB = 268,435,456 日 = 22 8 

512 MB = 536,870,912 B=2”B 

1,024 MB = 1,073,741,824 B = 230 民 = 10? 也 


希腊 文中 的 giga 意味 着 巨大 ，1024 MB 也 就 被 顺 其 自然 地 称 为 1 吉 (8gigabyte ) 字 节 ，, 缩 
写 为 GB。 


同 理 ，!1 太 字 节 ( terabyte，teras 希腊 语意 思 为 巨人 ) 表示 2 个 字 节 ( 约 为 102 )， 
也 就 是 1,099,511,627, 776 个 字 节 ， 太 字 节 的 缩写 为 TB。 


1 KB 近似 为 1000 个 字 节 ，1 MB 近似 为 100 万 个 字 节 ，1 GB 近似 为 10 亿 个 字 节 ，1 
TB 近似 为 1 万 亿 个 字 节 。 


比 TB 还 高 数量 级 平时 一 般 很 少 使 用 ， 比 如 22 个 字 节 表示 为 1 批 字 节 (petabyte )， 
计算 出 来 就 是 1,125,899,906,842,624 个 字 节 ， 约 等 于 一 干 万 亿 ， - 105 字 节 。1 安 字 节 
(exabyte ) 代表 2 个 字 节 ， 也 就 是 1,152,921,504,606,846,976 个 字 节 ， 约 为 100 万 的 3 次 
方 , 即 10% 。 


我 们 来 补充 一 些 生活 中 的 基本 常识 。 在 写本 书 时 ( 1999 年 ), 家 用 电脑 的 随机 存储 器 
的 容量 一 般 为 了 2 MB、64 MB 或 128 MB (为 了 避免 混 清 ， 这 里 的 任何 描述 都 不 涉及 硬盘 
驱动 器 的 住 何 内 容 ， 范 围 仪 仪 限定 为 RAM )， 通 过 计算 可 以 得 到 它们 的 存储 大 小 分 别 为 
33,554,432 个 字 节 、67,108,864 个 字 节 和 134,217,728 个 字 节 。 


简洁 明了 是 我 们 人 类 交流 方式 的 一 大 特色 。 比 如 ， 家 中 电脑 内 存 大 小 如 果 为 65,536 
字 节 , 我 们 会 说 “我 的 是 64 玉 (这 句 话 很 可 能 是 在 1980 年 听 到 的 ;家 中 电脑 内 存 大 小 
如 果 为 33,554 ,432 字 节 ， 我 们 会 说 “我 的 是 32 M”"。 有 少数 电脑 配备 了 1.073,741,824 字 
节 的 内 存 ， 他 们 或 许 会 说 “我 的 可 是 上 了 G 的 《有 时 这 名 话 的 英文 表述 会 让 人 误 以 为 你 
在 谈论 音乐 


Tve got a gig )’。 
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一 二 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


| 


有 时 和 人们 可 能 会 用 到 千 比 特 或 光 比 特 ( 注意 是 比特 而 不 是 字 节 ), 这 只 是 极 少数 情况 。 
当 我 们 讨论 涉及 存储 器 的 相关 问题 时 ， 通 常 使 用 的 是 字 节 数 而 非 比特 (需要 的 时 候 可 以 
通过 把 字 节 数 乘 以 8 将 其 转换 成 比特 )。 有 一 种 情况 下 我 们 会 经 常用 到 干 比特 和 兆 比 特 ， 
那 就 是 在 描述 在 线路 中 流动 的 数据 时 ,很 多 句子 中 经 常会 出 现 千 比特 每 秒 (kbps ) 或 兆 比 
特 每 秒 (mbps ) 这 些 用 语 。 例 如 ， 一 台 56K 的 调制 解 调 器 指 的 是 其 数据 处 理 速 度 为 56 
干 比特 每 秒 ， 而 不 是 56 干 字 市 每 秒 。 


既然 我 们 已 经 学 会 如 何 构造 任意 大 小 的 RAM 阵列 ， 接 下 来 继续 对 这 个 问题 深究 下 
去 。 假 设 现在 已 经 构造 好 了 一 个 容量 为 65,536 字 节 的 存储 器 组 织 ， 如 下 图 所 示 。 


地 址 gp Adar 


和 


数据 输入 yD ee DG FE > 数据 输出 


写 操作 端 ,六 


为 什么 选择 大 小 为 64 KB 的 RAM 阵列 ? 而 非 32 KB 或 128 KB? 因为 65,536 是 一 个 
约 整数 ， 转 换 为 寡 的 形式 就 是 25， 这 个 RAM 阵列 需要 配备 16 位 的 寻 址 端 。 换 句 话说 ， 
该 地 址 恰好 可 以 用 2 个 字 节 表示 。 将 地 址 范围 转化 为 十 六 进 制 就 是 0000h~ FFFFh。 


我 前 面 也 提 到 过 ，64 KB 的 内 存 是 1980 年 的 个 人 电脑 的 主流 配置 ， 但 它 的 确 不 是 用 
电报 继电器 组 成 的 。 我 们 可 以 用 继电器 来 组 成 一 块 内 存 吗 ? 我 也 相信 你 不 想 这 人 么 做 。 在 
我 们 先前 的 讨论 中 ， 存 储 每 个 比特 需要 9 个 继电器 ， 推 算 一 下 64Kx8 的 RAM 阵列 就 需 
要 至 少 500 万 个 继电器 ! 


如 果 用 一 种 控制 面板 来 辅助 我 们 管理 对 这 块 64KB 存储 器 的 操作 一 一 包括 写 数 据 和 
读数 据 ， 一 切 将 会 直观 明了 。 在 这 款 控制 面板 上 ， 有 16 个 开关 用 于 控制 地 址 位 ， 还 有 8 
个 开关 用 来 控制 要 输入 的 8 比特 数据 。 写 操作 端 也 用 一 个 开关 来 表示 ,8 个 灯泡 用 来 显示 
8 位 数据 ， 这 个 控制 面板 如 下 图 所 示 。 


初始 状态 下 所 有 的 开关 均 置 为 0。 其 中 右 下 角 有 一 个 标识 为 控制 端 ( takeover ) 的 开 
关 ， 这 个 开关 的 作用 是 确定 由 控制 面板 还 是 由 外 部 所 连接 的 其 他 电路 来 控制 存储 器 。 如 
果 其 他 电路 连接 到 与 控制 面板 相连 的 存储 器 ， 这 时 控制 端 置 0( 如 图 所 示 )， 此 时 存储 器 
其 他 电路 系统 接管 ， 控 制 面板 上 的 其 他 开关 将 不 起 任何 作用 ; 当 控制 端 置 1 时 ， 控 制 
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16 存储 器 组 织 了 一 
| 
面板 将 重新 获得 对 存储 器 的 控制 能 力 。 


加 ， 64KB RAM 的 控制 面板 


09099099999 


次 my Ai0 Ay A 9 y As , Ay Al Al A 


0 只 


写 操作 端 控制 端 


这 种 功能 可 以 用 一 些 2-1 选择 器 来 实现 。 仔 细 数 一 下 会 发 现 ， 我们 需要 25 个 2-1 选 
择 器 一 一 其 中 包括 16 个 地 址 输入 端 、8 个 数据 输入 端 ， 以 及 1 个 写 操作 端 。 电 路 如 下 图 
所 示 。 


当 控制 端 开关 断 开 时 ，RAM 阵列 的 地 址 端 、 数 据 输入 和 写 操作 端的 数据 全 部 来 源 于 
外 部 信号 ， 也 就 是 在 2-1 选择 器 的 左上 角 的 输入 信号 ; 当 控制 端 开关 闭合 ，RAM 阵列 的 


地 址 端 、 数 据 输入 端 和 写 操作 端的 数据 来 源 于 控制 面板 开关 发 出 的 信号 。 但 最 终 RAM 阵 
列 的 输出 信号 都 会 传输 到 8 个 灯泡 上 或 其 他 可 能 的 地 方 。 


写 操作 端 数据 输入 地 址 输入 25 个 开关 


25 个 2-1 选 择 器 


213 霹 


和 


下 面 这 幅 是 控制 面板 与 全 长 x8 长 AM 阵 刻 的 揽 辑 结构 框图 。 
挫 制 而 梳 


pi ok DO[C 芝 > 闭 据 输 由 


当 控 制 端 开 关闭 合 时 ， 通 过 操作 16 个 地 址 井 关 ， 可 以 选择 的 ,536 个 地 址 中 的 住 何 一 个 ， 
灶 泡 的 状态 将 表示 该 地 址 中 所 保存 的 8 位 数据 。 我 们 可 以 使 用 8 个 数据 开关 表示 出 一 个 
新 数 ， 然 后 把 号 操作 端 冒 1， 从 而 将 数据 号 入 存储器。 


564 长 x8 的 及 AM 阵列 利 控制 面 玻 这 一 组 合 的 确 很 实用 ， 它 可 以 帮助 我 们 存储 65,536 
个 8 位 数据 并 且 读 取 其 中 的 任意 一 个 。 与 此 同时 ， 我 们 也 给 其 他 部 件 提供 了 接 入 系统 的 
机 会 -一 需要 接 入 系统 的 通常 是 一 些 电 路 部 件 -一 -这 些 部 件 可 以 轻易 地 读 取 并 利用 存储 
器 中 存放 的 数据 ， 还 可 以 把 数据 写 入 存储 器 。 


关于 存储 器 有 一 个 问题 尤其 值得 我 们 注意 ， 而 且 需 要 特别 注意 。 在 学 习 第 11 章 的 时 
候 ， 我们 曾 介 绍 过 过 辑 门 的 概念 及 原理 ， 但 是 没有 画 出 组 成 姿 辑 门 的 单个 继电器 的 结构 
图 。 特 别 是 ， 当 时 没有 指明 每 个 继电器 都 与 基 个 电源 连接 在 一 起 。 只 要 继电器 连通 ， 电 
流 就 会 流 过 电磁 线圈 并 产生 磁场 ， 继 而 吸 下 金属 片 。 


一 个 辛 辛 苦 苦 装 满 65,536 字 节 珍贵 数据 的 64 长 x8 RAM 阵 刻 ， 如 果断 掉 电 源 ， 会 发 
生 什 么 事情 昵 ? 首先 所 有 的 电磁 铁 都 将 因为 没有 电流 而 失去 磁性 ， 随 着 “ 栖 ” 的 一 声 ， 
金属 片 将 骅 回 原 位 ， 所 有 继电器 将 还 原 到 未 触发 状态 。RAM 中 存储 的 数据 呢 ? 它们 将 如 
风 中 残 籼 般 消失 在 黑暗 由。 


正 因 为 如 此 ， 随 机 访问 存储 器 也 被 称 为 易 失 性 〈volatile ) 存储 器 。 为 了 保证 存储 的 
数据 不 丢失 ， 易 失 性 存储 器 需要 恒定 的 电流 。 
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我 们 人 类 的 创造 能 力 与 勤奋 精神 常常 令 我 感叹 不 已 ,但 人 类 的 本 性 却 是 相当 懒惰 的 。 
举 个 简单 而 又 常见 的 例子 , 我 们 总 是 不 情愿 工作 。 我们 对 工作 的 反感 是 如 此 的 强烈 -一 当 
然 人 类 也 很 聪明 一 -以 至 于 情愿 花费 大 量 的 时 间 去 设计 并 制造 一 些 设备 , 哪怕 这 些 设备 只 
能 将 工作 时 间 缩 减 几 分 钟 。 修 闲 地 躺 在 吊 床上 ， 看 着 自己 刚 发 明 的 新 奇 工具 自动 修剪 草 
坪 ， 疫 有 什么 事情 能 比 这 更 让 我 们 快乐 的 神经 为 之 一 动 了 。 


很 可 异 , 我 并 不 打算 在 本 章 中 介绍 自动 制 草 机 的 设计 。 在 这 里 我 们 将 学 会 设计 更 加 
先进 的 机 器 ， 目 标 就 是 要 使 加 减法 的 过 程 自动 化 ， 这 听 起 来 有 些 难 以 置信 。 但 是 ， 本 章 
最 终 设计 出 的 机 器 用 途 将 十 分 广泛 ， 因 为 它 可 以 解 块 所 有 能 用 加 、 减 法 处 理 的 问题 ， 而 
事实 上 现实 中 的 很 多 问题 都 是 可 以 用 加 法 与 减法 来 解决 的 。 


当然 ， 随 着 机 器 变 得 越 来 越 精 密 ， 其 复杂 程度 也 越 来 越 高 ， 因 此 对 其 构造 的 某 些 部 
分 理解 起 来 比较 困难 。 因 此 如 果 你 略 去 了 某 些 复 杂 的 细节 ， 这 也 是 在 情理 之 中 ,没有 人 
会 为 此 责怪 你 。 有 时 ,我们 会 感到 焦躁 不 家 ， 甚 至 厌倦 ， 发 暂 再 也 不 会 为 了 解决 一 个 复 
杂 的 数学 难题 而 去 求助 于 某 些 电子 或 机 械 设备 。 但 是 请 保持 耐心 ， 在 本 章 的 末尾 我 们 将 
会 设计 出 一 种 机 器 ， 我 们 可 以 称 它 为 计算 机 〔 Computer )。 


回忆 我 们 曾 在 第 14 章 讨论 过 的 一 个 加 法 器 。 这 个 版 本 的 加 法 器 包括 一 个 8 位 的 锁 存 


一 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 
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器 ， 用 于 对 8 个 开关 的 输入 数据 进行 迭代 求 和 。 下 面 是 其 结构 图 。 


从 图 中 可 以 看 由 ，8 位 锁 存 器 利用 触发 器 来 保存 8 位 数据 。 使 用 这 个 设备 时 ， 首 先入 
要 按 下 请 零 开 关 使 锁 存 器 中 的 内 容 全 部 都 变 为 0, 然后 通过 开关 输入 第 一 个 数 。 加 法 器 上 
是 简单 地 将 这 个 数字 和 锁 存 器 输出 的 0 进行 求 和 ， 因 此 相 加 的 结果 与 原先 输入 的 数字 是 
一 样 的 。 按 下 相 加 开关 可 以 把 这 个 数 保存 在 锁 存 器 中 ， 最 后 会 点 亮 某 些 灯泡 以 显示 它 。 
现在 通过 开关 输入 第 二 个 数 ， 加 法 器 把 它 与 已 经 存放 在 锁 存 器 中 的 第 一 个 数 相 加 。 再 次 
按 下 相 加 开关 ， 就 可 以 把 相 加 的 结果 存 入 锁 存 器 中 ， 并 通过 灯泡 显示 这 个 结果 。 通 过 这 
种 方式 ， 可 以 把 一 串 数 相 加 并 显示 运行 结果 。 显 然 ， 这 种 设计 方案 存在 一 个 缺陷 : 8 个 灯 
泡 无 法 显示 大 于 255 的 数 。 
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对 于 第 14 章 所 介绍 的 这 种 电路 , 目前 为 止 只 讲 到 了 一 种 锁 存 器 , 它 是 电 平 触发 ( level 
triggered ) 的 。 在 电 平 触发 的 锁 存 器 中 ， 为 了 保存 数据 必须 将 时 钟 输入 端 首先 置 1， 然 后 
回 置 为 0。 当 时 钟 输入 端 为 1 时 ， 锁 存 器 的 数据 输入 端 可 以 改变 ， 而 这 些 变化 将 会 影响 到 
数据 输出 。 在 第 14 章 的 后 半 部 分 还 介绍 了 边沿 触发 (edge-triggered ) 的 锁 存 器 ， 这 种 锁 
存 器 在 时 钟 输入 从 0 跳 变 为 1 的 瞬间 保存 数据 。 边 治 触发 器 在 很 多 方面 更 加 易于 使 用 ， 
因此 假定 本 章 用 到 的 所 有 触发 器 都 是 边沿 触发 的 。 


用 来 累加 多 个 数 的 锁 存 器 称 做 累加 器 (accumulator )。 在 本 章 的 后 面 将 会 看 到 累加 器 
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不 仅仅 做 简单 的 累加 ， 它 还 充当 着 锁 存 器 的 角色 ， 保 存 第 一 个 数 ， 并 且 和 下 一 个 数 做 加 
法 或 减法 运算 。 

很 显然 ， 上 面 的 加 法 器 存在 着 一 个 很 大 的 缺陷 : 假如 要 把 100 个 二 进 制 数 加 起 来 ， 
你 必须 端 坐 于 加 法 器 前 ， 并 且 耐 心地 输入 所 有 的 数 并 累加 起 来 。 但 是 当 你 终于 完成 时 ， 
却 发 现 其 中 有 两 个 数 输 错 了 ， 而 你 只 能 重复 一 遍 所 有 的 工作 。 


但 是 ， 也 许 并 非 如 此 。 在 前 一 章 我 们 使 用 了 大 约 500 万 个 继电器 构造 了 一 个 64 KB 
的 RAM 阵列 。 除 此 之 外 , 我 们 还 把 一 个 控制 面板 连接 到 电路 帮助 我 们 工作 ， 闭 合 它 的 榨 
制 (Takeover， 有 些 书 中 也 称 “ 接 管 ”) 端 开 关 后 , 就 可 以 使 用 其 他 开关 来 控制 RAM 阵列 
的 读 写 。 下 面 是 64 KB RAM 阵列 结构 图 。 


如 果 把 这 100 个 二 进 制 数 输入 到 RAM 阵列 中 而 不 是 直接 输入 到 加 法 器 中 , 一 旦 需要 
修改 一 些 数据 ， 我 们 的 工作 将 会 变 得 容易 得 多 。 


控制 面板 


地 址 -E> Addr 


4Kx8 
RAM 


DG > 数据 输出 


因此 我 们 所 现在 面临 的 挑战 就 是 如 何 把 RAM 阵列 和 累加 器 连接 起 来 。 很 显然 , RAM 
阵列 的 输出 信号 可 以 替代 加 法 器 的 开关 。 而 你 也 许 想 不 到 ， 用 一 个 16 位 的 计数 器 (比如 
我 们 在 14 章 构造 的 那 种 ) 就 可 以 控制 RAM 阵列 的 地 址 信号 。 在 这 个 电路 中 ,RAM 阵列 
的 数据 输入 信号 和 写 操作 端 信 号 可 以 省 去 。 修 改 后 的 电路 结构 如 下 图 所 示 。 
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灯泡 

当然 ， 这 并 不 是 迄今 发 明 的 最 易于 使 用 的 计算 设备 。 要 使 用 它 ， 首 先 要 闭合 清 零 开 
关 ， 这样 做 的 目的 是 ， 清 除 锁 存 器 中 的 内 容 并 把 16 位 计数 器 的 输出 置 为 000h， 然后 闭 
合 RAM 控制 面板 的 控制 端 开关 。 现 在 你 可 以 从 地 址 0000h 开始 输入 一 组 你 想 要 相 加 的 8 
位 数 。 如 果 有 100 个 数 , 那 么 它们 将 被 存放 在 0000h ~ 0063bh 的 地 址 空间 中 ( 也 应 该 把 RAM 
阵列 中 未 使 用 的 单元 设置 为 00b )。 然 后 闭合 RAM 控制 面板 的 控制 端 开 关 〈 这 样 控 制 面 
板 就 不 再 控制 RAM 阵列 了 )， 同 时 断 开 清 零 开 关 。 做 完了 这 些 ， 我 们 可 以 静 静 地 坐 下 来 ， 
观察 灯泡 显示 运算 结果 。 


让 我 们 来 看 一 下 它 是 怎样 工作 的 ， 当 清 零 开关 第 一 次 断 开 时 ，RAM 阵 刻 的 地 址 输入 是 
0000h。RAM 阵列 的 该 地 址 中 存放 的 8 位 数值 是 加 法 器 的 输入 数据 。 加 法 器 的 另 一 个 输入 数 
据 为 00h， 因 为 此 时 锁 存 器 也 已 经 清 零 了 振荡 器 提供 的 时 钟 信号 一 一 个 可 以 在 0，1 之 闻 快 
速 切 换 的 信号 。 清 寒 开关 断 开 后 ， 当 时 钟 信号 由 0 嗲 变 为 1 时 ， 将 有 两 件 事 同时 发 生 : 锁 存 器 
保存 加 法 器 的 计算 结果 ， 同 时 16 位 计数 器 增 1， 指 向 RAM 阵列 的 下 一 个 地 址 单元 。 清 零 开关 
断 开 之 后 ， 时 钟 信 号 第 一 次 从 0 内 变 为 1 时 ， 锁 存 器 就 将 第 一 个 数值 保存 下 来 ， 同 时 计数 器 增 
加 为 0001h; 当 时钟 发 生 第 二 次 哈 闻 时 ， 锁 存 器 保存 之 前 两 个 数 的 求 和 结果 ， 同 时 计数 器 增加 
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为 0002h; 按 这 种 方式 往复 操作 。 

要 注意 的 是 ， 这 里 首先 做 了 一 些 假设 。 最 主要 的 一 点 就 是 ， 振 荡 峰 要 足够 慢 以 使 电 
路 的 其 他 部 分 可 以 工作 。 每 次 时 钟 振 荡 的 过 程 中 ,在 加 法 器 输出 有 效 的 结果 之 前 ， 一 些 
继电器 必须 去 触发 其 他 继电器 。 


这 个 电路 存在 的 一 个 缺陷 是 : 我 们 没有 办 法 使 它 停 下 来。 在 基 : 一 个 时 刻 ， 所 有 灯泡 

会 停止 发 光 ， 因 为 六 AM 阵列 的 剩余 部 分 存放 的 数 都 是 09h。 这 时 ， 你 可 以 读 取 二 进 制 的 
运算 结果 :。 但 是 当 计数 器 达到 FFFFh 时 ， 它 会 重新 加 滚 (roll over ) 到 0000h ( 这 就 好 像 
汽车 的 里 程 表 一 样 )， 这 时 自动 加 法 器 会 青 一 次 把 所 有 的 数 办 加 到 已 经 计算 出 来 的 结果 中 
上 


这 个 加 法 器 还 存在 习 一 个 问题 ; 它 只 能 做 加 法 运算 ， 开 且 只 能 做 8 位 数 的 加 法 。 在 
这 个 RAM 阵列 中 ， 不 但 每 一 个 数 要 小 于 26$， 而 且 任 意 个 数 相 加 的 结果 也 要 小 于 355。 
上 外， 该 加 法 器 也 千 能 处 理 碱 法 运算 ， 尽 管 可 以 用 2 的 补 数 表 十 负数， 但 在 运 神 情况 | 
加 法 器 能 处 理 的 数字 的 范围 被 限制 在 -412 到 127 之 间 。 要 处 理 刘 大 的 数 ( 例如 ，16 位 数 ， 
的 厨 ， 一 个 简单 的 方法 是 :把 KAM 阵 记 、 加 半 器 镇 在 器 的 位 宽 宝 都 加 倍 ， 同 时 增加 
个 灯 驴 。 但 运 些 投 密 在 忽 们 看 来 是 二 让 算 抽 1。 


当 芍 ， 这 里 提 划 运 个 问题 的 原因 是 最 兹 工 们 要 解 块 它 。 但 首先 来 关 诗 另 一 个 问题 ， 
如 果 你 站 需要 把 100 个 数 加 在 一 起 呢 7 如 肾 你 想 做 的 是 用 自动 加 法 器 把 50 对 数 分 强 相 
加 ,得 出 50 个 不 同 的 结果 呢 ? 或 者 你 需要 一 神力 能 机 ， 它 可 以 方便 地 对 两 个 数 ，10 个 数 
甚至 100 个 数 求 衫 ， 并 且 所 有 的 计算 结果 都 可 以 很 方便 地 使 用 。 


先前 提 到 的 自动 加 法 器 都 是 用 连接 在 锁 存 器 上 的 灯泡 来 显示 运行 结果 的 ， 但 是 如 果 
你 想 对 50 对 数 分 别 求 和 的 时 候 ， 这 就 不 是 一 个 好 的 方法 了 。 你 可 能 会 想到 把 运算 结果 在 
加 到 RAM 阵列 中 去 ， 这 样 的 话 ， 就 可 以 在 适当 的 时 候 用 RAM 阵列 的 控制 面板 来 检查 运 . 
算 结 果 。 为 了 实现 这 个 目的 ， 控 制 面板 上 专门 设计 了 灯泡 。 

这 意味 着 我 们 可 以 去 掉 与 锁 存 器 连接 的 灯泡 , 取而代之 的 是 把 锁 存 器 的 输出 端 连 接 
到 RAM 阵列 的 数据 输入 端 ， 这 样 就 可 以 把 计算 结果 写 回 到 RAM 阵列 中 去 ， 如 下 图 所 
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上 图 中 略 去 了 自动 加 法 器 的 其 他 部 分 ， 其 中 包括 振荡 器 和 清 零 开关 ， 这 是 因为 我 们 
再 需要 特别 标注 计数 器 和 锁 存 器 的 清 零 及 时 钟 输入 。 此 外 ， 了 既然 我 们 现在 已 经 开始 利 
RAM 的 数据 和 输入， 因此 需要 一 种 用 来 控制 RAM 写 入 信号 的 方法 。 
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现在 我 们 不 需要 担心 电路 能 否 工 作 ， 而 要 把 注意 力 集中 到 急需 解决 的 问题 上 来 。 目 
前 的 当务之急 是 如 何 配置 一 个 自动 加 法 器 ， 使 它 不 仅仅 可 以 对 一 组 数字 做 昧 加 运算 ， 还 
希望 它 能 够 自主 地 确定 要 累加 多 少 个 数字 , 而 且 还 能 记 住 在 RAM 中 存放 了 多 少 个 计算 结 
果 ， 这 样 就 可 以 简化 查询 工作 。 
例如 ， 假 设 我 们 先 要 对 三 个 数 进 行 求 和 ， 然 后 对 两 个 数 进 行 求 和 ， 最 后 再 对 三 个 数 
进行 求 和 。 想象 一 下 , 我 们 可 以 把 这 些 数 保存 在 RAM 阵列 中 以 0000h 开始 的 一 组 空间 中 ， 
这 些 数 存储 在 RAM 阵列 中 的 具体 形式 如 下 图 所 示 。 
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因为 地 址 是 线性 的 ， 所以， 
该 存储 单元 内 容 的 注释 ， 这些 标记 的 单元 就 是 我 们 想 要 自动 加 法 出 保存 三 个 计算 结果 的 
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中 将 用 这 样 的 形式 表示 一 小 段 存 储 器 。 方 格 表示 的 是 存储 器 的 内 容 。 存 储 器 的 


有 。 地 址 标记 在 方 格 的 左边 ， 并 不 是 每 一 个 地 址 都 需要 标记 ， 
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的 ， 它 们 总 是 保存 着 一 些 


不 是 实验 的 


但 这 3 


我 们 六 


目的 ,我 们 想 要 
F 不 希望 自动 加 法 器 成 为 


存放 的 是 一 些 没有 | 


种 冲动 ， 想 亲自 去 做 十 六 进 制 计算 ， 并 把 结 
自动 加 法 器 为 我 们 做 这 些 加 


任务 系统 一 一 在 它 的 第 一 个 版 本 中 , 只 是 把 RAM 地 


的 数 )。 


填 到 那些 小 格子 


法 。 


如 


址 中 的 内 容 加 到 称 为 累加 器 的 8 位 锁 存 器 中 一 实际 上 我 们 希望 它 能 做 四 件 事 : 进行 加 法 


操作 ， 首 先 它 
二 个 操 
的 计算 


来 。 


我 们 借助 具体 的 例子 详细 


要 把 


结果 取出 并 存放 到 存储 器 


个 字 节 从 存储 器 中 传送 到 累加 器 中 ， 这 个 操 
作 把 存储 器 中 的 一 个 字 节 加 《Add ) 到 累加 器 的 内 容 中 去 。 
1。 忆 外 我 们 需要 用 一 个 方法 令 


作 称 为 加 载 (Load )。 第 
第 三 个 操作 把 累加 器 中 
自动 加 法 器 停 (Halt ) 下 


来 说 明 。 


过 程 ， 


以 上 文 提 到 的 自 


动 加 法 器 所 做 的 运算 为 例 
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(1) 把 0000h 地 址 处 的 内 容 加 载 到 累加 器 。 
(2) 把 0001h 地 址 处 的 内 容 加 到 累加 器 中 。 
(3 ) 把 0002h 地 址 处 的 内 容 加 到 累加 器 中 。 
(4) 把 累加 器 中 的 内 容 存储 到 0003h 地 址 处 。 
(5 ) 把 0004h 地 址 处 的 内 容 加 载 到 累加 器 。 
(6) 把 0005h 地 址 处 的 内 容 加 到 累加 器 。 

《7) 把 累加 器 中 的 内 容 存储 到 0006h 地 址 处 。 
(8) 把 0007h 地 址 处 的 内 容 加 载 到 累加 器 。 
(9) 把 0008h 地 址 处 的 内 容 加 到 累加 器 。 
(10) 把 0009h 地 址 处 的 内 容 加 到 票 加 器 。 
(11) 把 累加 器 中 的 内 容 存储 到 000Ah 地 址 处 。 
(12) 令 自 动 加 法 器 停止 工作 。 


这 里 要 注意 ， 同 最 初 的 自动 加 法 器 一 样 ， 存 储 器 中 的 每 一 个 字 节 的 地 址 仍然 是 以 
0000h 为 起 点 线性 排列 的 。 最 初 的 加 法 器 只 是 简单 地 把 存储 器 指定 地 址 的 内 容 和 累加 器 中 
的 内 容 相 加 , 在 革 些 情况 下 需要 这 样 做 。 但 是 有 时 我 们 需要 把 存储 器 中 的 某 个 值 直 接 加 载 
到 累加 器 ， 或 者 把 累加 器 中 的 值 直接 保存 到 存储 器 。 做 完了 这 些 工 作 ， 算 得 上 万 事 俱 备 只 
穴 东 风 了 ， 我 们 还 希望 自动 加 法 器 能 方便 地 停 下 来 ， 以 便于 查看 RAM 阵列 中 存放 的 值 。 


该 如 何 来 完成 这 些 工作 呢 ? 能 不 能 仅仅 简单 地 向 RAM 阵列 中 输入 一 组 数 , 然后 期 待 
自动 加 法 器 正确 地 完成 所 有 工作 昵 ? 答案 是 否定 的 。 对 于 RAM 阵列 中 的 每 一 个 数 , 我 们 
还 需要 用 一 些 数字 代码 来 标识 加 法 器 要 做 的 每 一 项 工作 : 加 载 、 相 加 、 保 存 和 终止 。 


也 许 存放 这 些 代码 的 最 简单 的 方法 〔 但 肯定 不 是 代价 最 小 的 ) 是 把 它们 存放 在 一 个 
独立 的 RAM 阵列 中 。 这 个 RAM 应 该 和 第 一 个 RAM 同时 被 访问 。 但 是 这 个 RAM 中 存 

放 的 是 不 需要 求 和 的 数 , 而 是 一 些 数字 代码 ， 用 来 标记 自动 加 法 器 对 第 一 个 RAM 中 指定 
地 址 要 做 的 一 种 操作 。 这 两 个 RAM 可 以 分 别 被 标记 为 “数据 ”( 第 一 个 RAM 阵列 ) 和 
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“代码 ”( 第 二 个 RAM 阵列 )。 其 结构 如 下 图 所 示 。 


16 位 计数 大 


我 们 已 经 清楚 地 认识 到 新 的 自动 加 法 器 能 够 把 数据 求 和 的 结果 写 入 到 第 一 个 RAM 


阵列 (标记 为 “数据 ”)， 而 新 的 RAM 阵列 (标记 为 “代码 ”) 则 只 能 通过 控制 面板 写 入 。 


我 们 需要 四 个 代码 来 标记 新 的 自动 加 法 器 需要 做 的 四 个 操作 ， 这 些 代码 可 以 任意 指 


定 。 如 下 所 示 的 是 一 种 方案 。 


人 


操作 码 
Load (加 载 ) 
Store (保存 ) 


Aid (加法 ) 
Hait( 售 上 ) 


为 了 使 上 面 讨论 的 三 组 加 法 得 以 正常 执行 ， 你 需要 通过 控制 面板 把 如 下 值 存 入 代码 


RAM 阵列 。 


比较 一 下 该 RAM 阵列 与 存放 累加 数据 的 RAM 阵列 中 的 内 容 , 你 会 发 现 , 代码 RAM 


阵列 中 存放 的 每 一 个 代码 都 对 应 着 数据 RAM 中 要 被 加 载 或 者 加 到 累加 器 中 的 数 , 或 者 对 
应 需要 存 回 到 数据 RAM 中 的 某 个 数 。 以 这 种 方式 使 用 的 数字 代码 常常 被 称 为 指令 码 


( 


instruction code ) 或 操作 码 ( operation code，opcode )。 它 们 指示 电路 要 执行 的 某 种 操作 。 
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编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


OOO0b: | Oh | Load 


W004b: 
Add 
} | Store 


UO07h: 


如 前 所 述 , 最 初 的 自动 加 法 器 的 8 位 锁 存 器 的 输出 要 作为 数据 RAM 阵列 的 输入 , 这 
就 是 Save 指令 的 功能 。 还 需要 做 另 一 个 改变 : 以 前 8 位 加 法 器 的 输出 是 8 位 锁 存 器 的 输 
入 , 但 现在 为 了 执行 Load 指令 , 数据 RAM 阵列 的 输出 有 时 也 要 作为 8 位 锁 存 器 的 输入 ， 
这 种 新 的 变化 需要 一 个 2-1 选择 器 来 实现 。 改 进 后 的 自动 加 法 器 如 下 图 所 示 。 


图 中 略 去 了 一 些 组 件 ， 但 是 仍然 清晰 地 描述 了 各 个 组 件 之 间 的 8 位 数据 通路 。16 位 
的 计数 器 为 两 个 RAM 阵列 提供 地 址 输入 。 通 常 ， 数 据 RAM 阵列 的 输出 传 入 到 8 位 加 法 
器 执行 加 操作 。8 位 锁 存 器 的 输入 可 以 是 数据 RAM 阵列 的 输出 〈 当 执行 Load 指令 时 )， 
也 可 以 是 加 法 器 的 输出 〈 当 执行 Add 指令 时 )， 这 种 情况 下 就 需要 2-1 选择 器 。 通 常 ， 锁 
存 器 电路 的 输出 又 流 回 到 加 法 器 中 ,但 是 当 执行 Save 指令 时 ， 它 就 成 为 了 数据 RAM 阵 
列 的 输入 数据 。 
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控制 面板 
站 
5 了 Kx 过 |- -代码 
PoE 代码 
L | 


控制 面板 


网 


上 图 缺少 的 是 控制 所 有 这 些 组 件 的 信号 ， 它 们 统称 为 控制 信号 ， 包 括 16 位 计数 器 的 
“时 钟 ”输入 和 “ 清 零 ”输入 ，8 位 锁 存 器 的 “时 钟 ” 输 入 和 “ 清 零 ”输入 , 数据 RAM 阵 
列 的 “ 写 ”(W ) 输入 ，2-1 选择 器 的 “选择 ”($ ) 输入 。 其 中 的 一 些 信 号 很 明显 是 基于 
代码 RAM 阵列 的 输出 , 例如 ,如 果 代码 RAM 阵列 输出 是 Load 指令 , 那么 2-1 选择 器 的 
“选择 ”输入 必须 是 0( 即 选 择 数 据 RAM 的 输出 )。 只 有 当 操作 码 是 指令 Store 时 ， 数 据 
RAM 阵列 的 “ 写 ”( W ) 输入 必须 是 1。 这 些 控制 信号 可 以 通过 逻辑 门 的 各 种 组 合 来 实现 。 


利用 最 少 的 附加 硬件 和 一 些 新 增 的 操作 码 ， 可 以 让 这 个 电路 从 累加 器 中 减 去 一 个 数 。 
第 1 步 是 向 操作 码 表 增 加 一 些 代码 。 
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和 


“操作 码 代码 


op 1 3 ) 
Hatt 


对 于 Add 和 Subtract 的 代码 ， 其 区 别 仅 在 于 最 低 有 效 位 ， 我 们 称 该 位 为 Co。 如 果 操 
作 码 为 21h, 除了 数据 RAM 阵列 的 数据 传 入 加 法 器 之 前 要 取 反 ， 并 且 加 法 器 进位 输入 置 
1 之 外 , 电路 所 做 的 操作 与 执行 Add 指令 所 做 的 操作 相同 。 在 这 个 增加 了 一 个 反 相 器 的 改 
进 电路 中 ，Co 信 号 可 以 完成 这 两 项 任务 。 改 进 后 的 电路 结构 图 如 下 。 


16 位 计 笋 器 医 
Li 


Addt 


[TN 
ha a Fermi 


| : 司 
}_ic 8 位 加 法 类 


假设 现在 要 把 56h 和 2Ah 相 加 , 然后 再 从 中 减 去 38h， 可 以 按照 下 图 中 两 个 RAM 阵 
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i 自动 操作 本 


列 中 的 代码 (操作 码 ) 和 数据 (操作 数 ) 完成 该 运算 。 

代码 欢 据 
oh | Load 000gh: | 5 
| Add 


tract 


O00h: 


Store 中 一 结果 保存 在 此 处 


Hair 


Load 操作 完成 之 后 ， 累 加 器 中 的 值 更 新 为 56h， 加 法 操作 完成 后 累加 器 中 的 值 为 56h 
与 2Ah 的 和 ， 即 80h。Subtract 操作 使 数据 RAM 阵列 的 下 -一 个 值 ( 38h ) 按 位 取 反 ,得 到 
C7h。 当 加 法 出 的 进位 输入 置 1 时 ， 取 反 得 到 C7h， 然 后 使 其 与 80h 相 吉 :; 
Ch 
+ 又 (ji 
二 由 
45h 


最 后 的 结果 是 48h。([ 在 十 进 制 中 ，86 加 息 再 霹 去 56 等 于 72) 


还 有 一 个 一 直 漫 有 找 惠 音 造 的 解 志 办 鞭 的 门 题 : 而 法 雍和 基 连 接 到 它 的 所 有 请 备 的 章 
度 只 有 8 位 ;以 前 提出 过 的 一 个 解决 办 法 是 把 两 个 8 位 加 法 器 (其 他 的 大 部 分 设备 也 用 
两 个 ) 连 在 一 起 ， 梅 成 -- 个 16 位 的 设备 。 


但 还 有 代价 更 小 的 解决 办 法 ， 假 如 你 想 把 其 个 16 位 的 数 相 加 ， 比 如 ; 
76ABh 
十 232Ch 


这 种 16 位 的 加 法 先 单独 处 理 最 右边 的 字 节 【通常 称 之 为 低 字 节 小 
ABh 


+2Ch 
D7?7h 


后 再 计算 最 左边 的 字 节 ， 即 高 字 节 的 和 : 
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机 


76h 
+23h 


99h 


得 到 相同 的 结果 99D7h。 因 此 ， 如 果 我 们 把 两 个 16 位 的 数 用 这 种 方式 保存 在 存储 器 中 ， 
就 像 下 面 这 样 : 


0000h: | ， 


运算 结果 D7b 将 被 保存 到 地 址 0002h， 而 结果 99h 将 被 保存 到 


地 址 0005h。 


当然 并 非 所 有 的 情况 都 是 这 样 处 理 ， 只 是 上 面 的 例子 中 用 到 了 这 种 方法 。 如 果 要 把 


76ABh 和 236Ch 这 两 个 16 位 的 数 相 加 该 怎么 做 昵 ? 在 这 个 例子 中 , 对 两 个 数 的 低 字 节 求 
和 时 将 会 产生 一 个 进位 : 


ABh 
二 6Ch 
117h 


产生 的 这 个 进位 必须 与 两 个 数 的 高 字 节 的 和 再 


lh 
+76h 
+23h 
9Ah 


最 后 的 计算 结果 为 9A17h。 


我 们 能 够 改进 自动 加 法 器 的 电路 ， 使 它 可 以 正确 地 进行 16 位 数 的 加 法 操作 吗 ? 管 案 
是 肯定 的 ， 我 们 需要 做 的 仅仅 是 在 第 一 步 运算 时 保存 低 字 节 数 运算 的 进位 输出 ， 并 把 它 
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作为 下 一 步 高 字 节 数 运算 的 进位 输入 。 如 何 保存 1 位 昵 ? 1 位 锁 存 器 就 是 最 好 的 选择 了 ， 
该 锁 存 器 应 该 被 称 为 进位 锁 存 器 Carry latch )。 


为 了 使 用 进位 锁 存 器 ， 还 需要 另 一 个 操作 码 ， 我们 称 之 为 “进位 加 法 ”( Add with 
Carry )。 当 进行 8 位 数 加 法 时 ,使 用 的 是 常规 的 Add 指令 。 加 法 器 的 进位 输入 是 0， 它 的 
进位 输出 将 会 保存 到 进位 锁 存 器 ( 尽管 它 根 本 不 会 被 用 到 )。 

如 果 要 对 两 个 16 位 的 数 进行 加 法 运算 ,我 们 仍然 使 用 常规 的 Add 指令 对 两 个 低 字 节 
进行 加 法 运算 。 加 法 器 的 进位 输入 是 0， 而 其 进位 输出 被 锁 存 到 进位 锁 存 器 中 。 当 把 两 个 高 
字 节 数 相 加 时 ， 要 使 用 新 的 Add with Carry 指令 。 在 这 种 情况 下 ,两 个 数 相 加 时 要 用 进位 锁 
存 器 的 输出 作为 加 法 器 的 进位 输入 。 因 此 ， 如 果 第 一 步 低 字 节 数 的 加 法 运算 有 进位 ， 则 该 
进位 将 用 于 第 二 步 高 字 节 数 的 加 法 运算 ; 如 果 没 有 进位 ， 则 进位 锁 存 器 的 输出 是 0。 


如 果 要 进行 16 位 数 的 减法 运算 , 则 还 需要 一 个 新 的 指令 , 称 为 “ 借 位 减法 "( Subtract 
and Borrow )。 通 常 ，Subtract 指令 需要 将 减 数 取 反 并 且 把 加 法 器 的 进位 输入 置 1。 进 位 输 
出 通常 不 是 1， 因 此 应 该 被 忽略 。 但 对 16 位 数 进行 减法 运算 时 ， 进 位 输出 应 该 保存 在 进 
位 锁 存 器 中 。 在 进行 第 二 步 的 高 字 节 减法 运算 时 ， 锁 存 器 保存 的 结果 应 该 作为 加 法 器 的 
进位 输入 。 


在 加 入 了 Add with Carry 和 Subtract and Borrow 之 后 ,目前 我 们 已 经 有 了 7 个 操作 码 ， 
如 下 表 所 示 。 


Add 


一 一 
Subtract 
Add with Carry ( 进位 加 法 ) 


Subtract with Borrow 上 借 位 减法 ) 
[Bt | 


在 执行 减法 或 借 位 减法 运算 时 ， 送 入 加 法 器 中 的 操作 数 需 要 进行 取 反 预 处 理 。 加 法 
器 的 进位 输出 是 进位 锁 存 器 的 数据 输入 。 无 论 何 时 ， 执 行 加 法 、 减 法 、 进 位 加 法 或 借 位 
减法 中 的 任 一 种 运算 ， 进 位 锁 存 器 都 是 同步 的 。 当 执行 减法 运算 ， 或 进位 锁 存 器 的 数据 
输入 为 1 且 正 在 执行 进位 加 法 或 者 借 位 减法 运算 时 ，8 位 加 法 器 的 进位 输入 都 是 置 1 的 。 
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et 语言 


需要 记 住 的 是 ， 只 有 当前 一 次 的 加 法 或 者 进位 加 法 操作 使 加 法 器 产生 进位 输出 时 ， 
Add with Carry 指令 才 会 使 8 位 加 法 器 的 进位 输入 署 1。 因 此 ， 只 要 进行 多 字 节 数 加 法 运 


算 , 不 管 实际 是 否 需要 ， 都 应 该 使 用 Add with Cany 指 


提 到 16 位 加 法 正常 进行 ， 可 用 如 下 方法 。 


代码 
G000h: Load D0000h: 
Add 
118 | SG 和 
Load 
22h | Adcd wirh Carry 
Store 


i tialr 
不 论 操 作 数 是 


增加 了 项 个 狂 共 | 操作 查 之 
位 数 的 加 靶 运 算 。 通 过 We 


和 


极 大 地 扩展 了 加 法 器 的 功能 ， 
司 以 对 16 位 数 . 24 位 数 、 妈 位 数 ，g 和 位 数 ， 


,我 们 已 经 


令 。 为 了 保证 编码 的 正确 ,使 前 面 


罕 节 运 扯 结果 保存 在 


字 节 运算 续 果 保存 在 


该 方法 都 可 以 正确 地 行 。 


它 不 有 局 限于 8 


其 空 密 之 和 位 的 数 进 行 加 沁 运 算 . 假如 营 ; 进 行商 让 12 位 数 7TA8028GCDh 和 565A872EEb 的 加 


， 我 们 仪 址 要 1 条 Add 指 
代码 

hh | Load 
起 汪 Ardd 


未 运 算 


全 UO0f: 


Seo 
于 sa 二 
Add with Carry 
Store 
Load 


SEOE 


toad 


Store 


FFh | Hatt 
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社 机 13 条 Add with Carry 指 帮 ， 


OOUOD: 


人 dt asth Carry 


Add with Carry 


如 十 图 所 办。 


~ 作 赛 入 运算 结果 保存 人 


< 第 二 全 了 闻 运 算 结 江 保 存 


字 节 运算 结果 保存 在 


字 节 运算 结果 保存 在 


1 


当然 ， 把 这 些 数 依 次 输入 存储 器 并 不 是 最 好 的 做 法 。 因 为 你 木 但 要 使 用 开关 来 输入 
这 些 数 ， 而 且 保 存 这 些 数 的 存储 单元 的 地 址 也 不 是 连续 的 。 例 如 ，7A892BCDh 从 最 低 字 
节 并 始 ， 每 个 字 节 依次 保存 在 0000h，0003h，0006h，0009h 中 。 厕 为 了 得 到 最 后 的 结果 ， 
还 需要 检查 0002h，0005h，0008h，000Bh 这 几 个 地 址 中 的 数 。 


除 此 之 外 ， 当 前 设计 的 自动 加 法 器 不 允许 在 随后 的 计算 中 重复 使 用 前 面 的 计算 结果 。 
假设 我 们 要 对 三 个 8 位 数 求 和 ， 然 后 再 从 中 减 去 一 个 8 位 数 并 保存 结果 。 这 可 能 需要 一 
条 Load 指令 ， 两 条 Add 指令 ， 一 条 gubtract 指令 以 及 一 条 Store 指令 。 但 如 果 想 从 原来 
的 求 和 结果 (3 个 8 位 数 的 和 ) 中 减 去 另 一 个 数 该 怎么 做 呢 ? 这 个 求 和 结果 已 经 不 能 被 访 
问 了 ， 每 次 我 们 使 用 它 的 时 候 都 必须 重新 计算 。 


产生 上 述 情况 的 原因 就 在 于 我 们 构造 的 自动 加 法 器 具有 如 下 的 特性 : 它 的 代码 存储 
器 和 数据 存储 器 是 同步 的 、 顺 序 的 ， 并 且 都 从 0000h 开始 寻 址 。 代 码 存储 器 中 的 每 一 条 
指令 对 应 数据 存储 器 中 相同 地 址 的 存储 单元 。- 一 旦 执行 了 一 条 Store 指令 ， 相 应 的 ， 就 会 
有 一 个 数 被 保存 到 数据 存储 器 中 ， 而 这 个 数 将 不 能 重新 加 载 到 累加 器 。 

要 解决 这 个 难题 ， 需 要 对 自动 加 法 器 的 庚 计 做 一 个 根本 性 的 量程 度 极 大 的 修改 ,， 这 


和 想法 实现 起 让 但 平 非常 困难 ,但 是 很 快 你 就 会 专 现 【我 希望 是 这 样 ) 改进 后 的 加 法 器 
具有 更 高 的 灵 祷 性 。 


现 de 上 县 前 已 经 有 了 7 个 a 人 所 示 。 


Subttact a 
Add with Cary C a ) 


每 一 个 操作 码 在 存储 器 中 占 1 个 字 节 。 现 在 除了 Halt 操作 码 外 ， 我 希望 每 一 个 指令 
在 存储 器 中 仅 占 据 3 个 字 节 的 空间 ， 其 中 第 一 个 字 节 为 代码 本 身 ， 另 外 的 两 个 字 节 用 来 
存放 1 个 16 位 存储 器 单元 地 址 。 对 于 Load 指令 来 说 ， 后 两 个 字 节 保存 的 地 址 用 来 指明 
数据 RAM 阵列 的 一 个 存储 单元 ， 该 单元 存放 的 是 需要 被 加 载 到 累加 器 中 的 字 节 。 对 于 
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一 篇 码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 


Add，Subtract，Add with Carry，Subtract with Borrow 指令 来 说 ， 该 地 址 指明 的 存储 单元 
所 保存 的 是 要 从 累加 器 中 加 上 或 减 去 的 字 节 。 对 于 Store 指令 来 说 ， 该 地址 指明 的 是 累加 
器 中 的 内 容 将 要 保存 到 的 存储 单元 地 址 。 


例如 ， 当 前 加 法 器 所 能 进行 的 最 简单 的 运算 就 是 对 两 个 数 求 和 。 为 了 执行 这 个 操作 ， 
需要 按 下 面 的 方式 设置 代码 RAM 阵列 和 数据 RAM 阵列 。 


代码 数据 


Load O000h: 
Add 
Store 


Hat 


在 改进 的 自动 加 法 器 中 ， 每 条 指令 (除了 Halt 指令 ) 需要 3 个 字 节 。 


代码 
把 00090h 地 址 处 的 字 节 
D000h 奖 入 黑 加 锋 子 
QO 
0603h: | 20b | 加 p999 直 把 由 处 的 字 
se 


O009h; 


每 一 条 指令 的 代码 (除了 Halt 指令 ) 后 跟 两 个 字 节 ， 用 来 指明 数据 RAM 阵列 中 16 位 的 


存储 地 址 。 这 三 个 地 址 恰巧 是 0000h，0001h 和 0002h， 但 它们 可 以 是 任何 其 他 可 用 的 地 
址 。 


前 面 讲 到 了 如 何 用 Add 或 Add with Carry 指令 来 对 两 个 16 位 数 一 一 比如 76ABh 和 
232Ch 求 和 。 必须 把 两 个 数 的 低 字 节 保存 到 存储 器 的 0000h 和 0001h 地 址 , 把 其 高 字 节 保 
存 到 0003h 和 0004h 地 址 ， 运 算 的 结果 分 别 保 存在 0002h 和 0005h。 


通过 这 种 变化 ， 我 们 可 以 用 一 种 更 合理 的 方式 来 保存 这 两 个 操作 数 及 其 运算 结果 ， 
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可 能 会 把 它们 保存 到 我 们 从 未 用 到 过 的 存储 区 域 。 


40009h: 


4002h: 


算 结 果 存 放 在 此 处 
算 结 果 存 放 在 此 处 


40048: 


这 6 个 存储 单元 不 必 像 上 图 中 这 样 全 都 连 在 一 起 ， 它 们 可 以 分 散在 整个 64 KB 数据 
RAM 阵列 的 任意 位 置 。 为 了 把 这 些 地 址 中 的 数 相 加 ， 代 码 RAM 阵列 中 的 指令 必须 用 以 
下 方式 设置 。 


停止 


0012h: | FEh 


可 以 看 到 ， 保 存在 地 址 4001h 和 4003h 处 的 两 个 低 字 节 数 先 执行 加 法 ， 其 结果 保存 
在 4005h 地 址 处 。 两 个 高 字 节 数 (分 别 保存 在 4000h 和 4002h 处 ) 通过 Add with Carry 指 
令 相 加 ， 其 结果 保存 在 地 址 4004h 处 。 如 果 去 掉 Halt 指令 并 向 代码 RAM 中 加 入 更 多 指 
令 ; 随后 的 计算 可 以 通过 引用 地 址 很 方便 地 使 用 原来 的 那些 操作 数 及 其 结果 。 


实现 该 设计 的 关键 是 把 代码 RAM 阵列 的 数据 输出 到 3 个 8 位 锁 存 器 中 。 每 个 锁 存 器 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| - 


保存 该 3 字 节 指令 的 一 个 字 节 。 第 一 个 锁 存 器 保存 指令 代码 本 身 ， 第 二 个 锁 存 器 保存 地 
址 的 高 字 节 ， 第 三 个 锁 存 器 保存 地 址 的 低 字 节 。 第 二 个 和 第 三 个 锁 存 器 的 输出 构成 了 数 
据 RAM 阵列 的 16 位 地 址 。 


一 各 | Cir 
16 位 计数 。 HE adar 人 区 
活 6 
地 


[2 
| 民 区 | AN Do 
bs = 


从 存储 器 中 取出 指令 的 过 程 称 为 取 指 令 ( instruction feteh )。 在 我 们 设计 的 加 法 器 中 ， 
每 一 条 指令 的 长 度 是 3 个 字 节 。 因 为 每 次 从 存储 器 取 同 一 个 字 节 ， 所 以 取 每 条 指令 需 
的 时 间 为 3 个 时 钟 周期 。 此 外 ,一 个 完整 的 指令 周期 需要 4 个 时 钟 周期 。 这 些 变化 必然 
使 得 控制 信号 更 加 复杂 。 


机 器 响应 指令 码 做 一 系列 操作 的 过 程 称 为 执行 (executs ) 指令 ， 但 这 并 不 能 表明 机 
若是 一 种 有 生命 的 东西 ， 因 为 它 不 能 自行 分 析 机 器 代码 并 决定 该 做 什么 。 每 一 种 机 器 码 
用 其 唯一 的 方式 触发 多 种 控制 信号 ， 从 而 引发 机 器 执行 各 种 操作 。 

注意 ， 为 了 让 上 面 的 加 法 器 更 如 有 用 ， 我 们 牺 竹 了 运算 速度 。 使 用 同样 的 振荡 器 ， 
它 的 运算 速度 只 有 本 章 提 到 的 第 一 个 加 法 器 的 1/4。 这 验证 了 一 个 称 为 TANSTAAFL 的 工 
程 准则 ， 它 的 意思 是 “天 下 没有 免费 的 午餐 "。 通 常 上 帝 总 是 很 公平 的 ， 你 改进 了 机 器 的 
某 个 方面 ， 则 其 他 方面 就 会 受到 损失 ， 有 得 就 有 失 。 


如 果 不 使 用 继电器 构造 这 个 电路 的 话 ， 很 显然 ， 两 个 64 KB 的 RAM 阵列 构成 了 电 
路 中 最 主要 的 部 分 。 事 实 上 早 就 应 该 放弃 这 些 部 件 了 ， 甚 至 从 一 开始 就 应 该 决定 只 需要 
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一 个 1 KB 的 存储 器 。 如 果 能 确定 所 有 的 数据 都 可 以 存放 在 0000k ~ 03FEh 的 地 址 空间 中 ， 
那么 使 用 一 个 小 于 64 攻 B 的 存储 锻 加 法 髓 也 可 以 很 好 地 工作 。 


但 是 你 现在 仍然 可 能 不 在 意 使 用 了 2 个 RAM 阵列 。 事 实 上 ， 确 实 不 必要 在 意 。 前 面 
介绍 了 两 种 kAM 阵列 ， 一 个 用 来 存放 指令 码 ， 另 一 个 用 来 存放 操作 数据 一 -这 种 设计 使 
得 自动 加 法 器 的 结构 非常 清晰 和 易于 使 用 。 但 现在 我 们 使 用 3 . 字 节 长 的 指令 格式 ， 第 二 
个 和 第 三 个 字 节 用 来 指明 操作 数 的 存 情 地 址 , 因此 就 没有 必要 再 使 用 两 个 独立 的 RAM 阵 
列 。 抬 作 和 码 和 操作 数 可 以 存放 在 同一 个 RAM 阵列 。 


为 了 实现 这 个 设计 ， 我 们 需要 一 个 生 1 选择 器 来 确定 如 何 对 RAM 阵列 寻 址 。 通 常 ， 
各 前面 的 方式 相同 ， 我 们 用 一 个 16 位 的 计数 器 来 计算 地 址 。 数 据 RAM 阵列 的 输出 仍然 
连接 到 3 个 锁 存 器 ， 分 别 用 来 保存 指令 代码 及 其 对 应 操作 数 的 16 位 地 址 ， 其 16 位 的 地 
址 输出 是 2-1 选择 器 的 第 二 种 输入 。 地 址 被 锁 存 后 ， 可 以 通过 选择 器 将 其 作为 RAM 阵列 
的 地 址 输入 。 


我 们 已 经 对 原 电 路 做 了 不 少 改进 ,现在 可 以 把 操作 指令 和 操作 数据 保存 在 同一 个 
RAM 阵列 中 。 例如, 下 图 演示 了 如 何 把 两 个 8 位 数 相 加 , 然后 从 结果 中 青 减 去 一 个 8 位 数 . 
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Te 编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 


把 0010h 地 址 处 的 字 节 装 入 
累加 器 


把 0011h 地 址 处 的 字 节 加 到 
肾 加 器 


累加 器 中 减 去 0012h 地 址 
处 的 字 节 


招 累 加 器 中 的 内 容 保 存 
到 0013h 地 址 处 0 


和 DO: 


9010h: | = 


最 终 的 结果 保存 在 此 处 


通常 ， 指 令 从 0000h 开始 存放 ， 这 是 因为 当 计 数 器 复位 后 从 该 位 置 访问 RAM 阵列 。 
最 后 的 Halt 指令 存放 在 000Ch 地 址 。 我 们 可 以 把 这 3 个 操作 数 及 它们 的 运算 结果 保存 在 
RAM 阵列 的 任何 地 址 ( 当然 这 不 包括 最 开始 的 13 个 字 市 ， 因 为 它们 已 经 用 来 存放 操作 


间 令 )， 所 以 我 们 选择 在 从 0010h 地 址 开始 保存 操作 数 。 


假设 现在 你 发 现 需 要 在 原来 的 结果 中 再 加 两 个 数 ， 你 可 以 向 存储 器 中 输入 一 些 新 的 


间 令 以 替换 原来 所 有 的 指令 ， 但 是 你 可 能 不 愿意 这 人 么 做 。 或 许 你 更 倾向 于 在 原 指 令 的 地 
址 后 增加 一 些 新 的 指令 。 第 一 步 要 做 的 就 是 把 000Ch 地 址 处 的 Halt 指令 替换 为 一 个 Load 
指令 。 但 你 仍然 需要 增加 两 条 Add 指令 ,一 条 Store 指令 ， 以 及 一 条 新 的 Halt 指令 。 


区 


一 的 问题 是 ， 现 在 0010h 地 址 已 经 保存 了 一 些 数据 ， 因 此 需要 把 这 些 数据 转移 到 较 高 的 


地 址 空间 中 ， 然 后 还 需要 修改 那些 指向 这 些 地 址 空间 的 指令 。 


试想 一 下 ， 把 操作 码 和 操作 数 存放 在 同一 个 RAM 阵列 并 不 是 一 个 急于 解决 的 问题 。 
但 可 以 肯定 的 是 ， 这 是 一 个 迟早 要 解决 的 问题 ， 不 如 现在 就 找 一 个 解决 办 法 吧 。 在 当前 
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ce 上 


的 例子 中 ， 也 许 你 更 愿意 从 0020h 地 址 开始 存放 新 的 指令 ， 并 从 0030h 处 开始 存放 新 的 
操作 数据 。 


0020kh: 把 0813h 地 址 处 的 字 节 装 入 累加 器 
把 003gh 地 扯 处 的 字 节 如 到 累加 器 


把 0031h 地 址 处 的 字 节 加 到 累加 器 


把 累加 器 中 的 内 容 保 存 到 0032h 地 
址 处 


停止 


最 终结 果 保 存在 此 处 


注意 , 第 一 条 Load 指令 所 指向 的 地 址 为 0013h, 这 个 位 置 保存 着 第 一 次 运算 的 结果 。 


现在 , 两 部 分 指令 的 位 置 分 别 起 始 于 地 址 0000h 和 0020h， 而 两 部 分 操作 数据 的 地 址 
> 别 起 始 于 0010h 和 0030h。 我 们 希望 自动 加 法 器 从 0000h 开始 执行 所 有 指令 完成 计算 任 


计 


我 们 必须 移 除 000Ch 处 的 Halt 指令 ， 这 里 的 移 除 是 指 用 其 他 代码 奉 换 它 。 但 仅仅 如 
此 是 不 够 的 ， 问 题 在 于 不 论 我 们 用 什么 来 替换 Halt 指令 ， 保 存在 地 址 000Ch 的 字 节 都 会 
被 当做 指令 代码 。 更 糟糕 的 是 ， 从 这 个 位 置 开 始 , 存储 器 中 每 隔 3 个 字 节 的 地 址 : 000Fh， 
0012h，0015h，0018h，001Bh 以 及 001Eh， 这 些 地 址 保存 的 字 节 也 会 被 当做 指令 代码 来 
处 理 。 如 果 其 中 的 一 个 字 节 恰好 为 11h( 这 是 Store 指令 的 代码 ) 将 会 发 生 什么 ? 如 果 Store 
指令 后 面 的 2 个 字 节 的 地 址 所 指向 的 位 置 刚 好 为 0023h, 那 又 会 发 生 什么 呢 ?” 它 导致 的 结 
果 是 ， 加 法 器 将 累加 器 中 的 内 容 写 入 这 个 地 址 ， 而 这 个 地 址 中 已 经 保存 了 重要 的 数据 。 
即使 这 些 情况 都 没有 发 生 ， 加 法 器 从 存储 器 的 001Eh 地 址 之 后 取 到 的 下 一 条 指令 的 位 置 
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sl 


将 是 0921h， 未 是 W239h， 市 事实 上 0020h 才 是 证 一 条 指令 的 存储 地 址 。 
要 是 保留 0090ch 地 址 处 的 Halt 指令 ， 我 们 能 寻求 到 更 好 的 解决 共 法 吗 ? 


不 过 ,我 们 可 以 用 一 个 称 为 Jatap ( 跳 转 ) 的 新 指令 来 替换 Halt 指令 。 现 在 把 它 加 入 
到 指令 表 。 


Bobi 时 


Subiiact with Botnsw 23 


Famb 甩 转 人 _ 
Halt a 


通常 情况 下 自动 加 法 器 是 以 顺序 方式 对 RAM 阵列 寻 址 的 。Tutap 指令 改变 了 机 岩 的 
这 和 圳 寻 址 方式 ， 取 而 代 之 的 是 从 基 个 指定 的 地 址 开始 寻 址 。 这 种 指令 有 时 也 被 称 作 分 支 
( braneh ) 指令 或 者 Geto 指令 ， 即 “ 转 到 另 -- 个 位 置 ”。 

在 上 面 的 例子 中 ， 我 们 可 以 用 一 个 jump 指令 来 替换 000Ch 地 址 处 的 Halt 指令 。 


DO0ch， 30h 屿 转 到 位 平 002dh 地 址 处 的 看 入 


30k 即 Jumb 指令 的 代码 。 其 后 的 两 个 字 节 中 存放 的 16 位 地 址 就 是 自动 加 法 器 要 执行 
的 下 一 条 指令 的 地 址 。 


因此 在 上 面 的 例子 中 , 自动 加 法 器 仍然 从 0000h 地 址 开始 , 依次 执行 一 条 Load 指令 ， 
一 条 Add 指令 ， 一 条 Subttaet 指令 和 一 条 gtore 指令 。 之 后 执行 一 条 jump 指令 ， 跳 转 至 
地 址 0020h 继续 依次 执行 一 条 Load 指令 ， 两 条 Add 指令 ， 一 条 Store 指令 ， 最 后 执行 一 
条 Hatt 指令 。 


Jurp 指令 通过 作用 于 16 位 计数 器 实现 其 功能 ,无 论 何 时 ,只 要 自动 加 法 器 遇 到 jump 


2238 


指令 ， 计 数 器 就 会 被 强制 输出 该 Jamp 指令 后 的 16 位 地 址 。 这 可 以 通过 16 位 计数 器 的 DD 
型 访 沿 触发 器 的 预 置 (Pre ) 和 清 零 (Clr ) 输入 来 实现 ; 


这 里 要 再 次 声明 , 在 正常 的 操作 下 , Pre 和 Clr 端的 输入 都 应 该 是 0。 但 是 , 当 Pre=1， 
Q=1; 当 Ch=1， 则 Q=0。 


如 果 你 希望 向 一 个 触发 器 加 载 一 个 新 的 值 ( 用 A 表示 ,代表 地 址 ), 可 以 像 下 图 所 示 


通常 ， 置 位 信号 为 0。 此 时 ,触发 器 的 预 置 端 输入 为 0, 在 复位 信号 不 为 1 的 情 识 下 ， 
清 零 信 号 也 为 0。 在 这 种 情 识 下， 触发 器 就 可 以 独立 清 零 ， 和 而 不 受 置 位 信号 的 影响 。 当 置 
位 信号 为 1 时 ， 如 果 A 为 1， 由 清 零 输入 为 0， 预 置 输入 为 1; 如 果 A 为 6， 则 预 置 输入 
0， 清 零 输 入 为 1。 这 就 意味 着 Q 端 将 被 设置 为 与 A 端 相 同 的 值 。 


我 们 需要 为 16 位 计数 器 的 每 一 位 设置 一 个 这 样 的 触发 器 。 一 旦 加 载 了 某 个 特定 的 值 ， 
计数 器 就 会 从 该 值 开 始 计数 。 

然而 ， 这 对 电 有 路 的 改动 并 不 是 很 大 。 从 RAM 阵列 锁 存 得 到 的 16 位 地 址 既 可 以 作为 
2-1 选择 器 ( 它 人 允许 该 地 址 作为 RAM 阵列 的 地 址 输入 ) 的 输入 , 也 可 以 作为 16 位 计数 器 
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es 


置 位 信号 的 输入 。 


| 
0 


显然 ， 只 有 当 指 令 代 码 为 30h 并 和 且 其 后 的 16 位 地 址 被 锁 存 时 ,我 们 才 必 须 确保 置 位 
信号 为 1。 


毋庸 置疑 ，Jump 指令 的 确 很 有 用 。 但 与 之 相 比 ， 一 个 在 我 们 想 要 的 情况 下 跳 转 的 指 
令 更 加 有 用 ,这 种 指令 称 做 条 件 跳 转 ( Conditional Jump )。 也 许 说 明 该 命令 重要 性 的 最 好 
方法 是 这 样 一 个 问题 : 怎样 让 自动 加 法 器 进行 两 个 8 位 数 的 乘法 运算 ? 例如 ， 我 们 如 何 
利用 自动 加 法 器 得 到 像 A7h 与 1Ch 相 乘 这 种 简单 运算 的 结果 呢 ? 


这 其 实 很 简单 。 两 个 8 位 数 相 乘 得 到 一 个 16 位 数 ， 为 了 方便 起 见 ， 把 该 匀 法 运算 中 
涉及 的 3 个 数 均 表示 为 16 位 数 。 第 一 步 确定 要 把 乘 数 和 乘积 保存 到 什么 位 置 。 


好 240 


17 ”自动 操作 


100(h: 16 位 乘 数 保存 在 此 处 
i1002bh:; 18 位 被 莱 数 保存 在 此 处 
T | 。 个 连续 的 存储 单元 


大 家 都 知道 A7h 和 1Ch 相 乘 的 结果 ( 即 十 进 制 的 28 ) 和 把 28 个 A7h 累加 的 结果 相 
同 。 因 此 保存 在 地 址 1004h 和 1005h 的 字 节 实际 上 是 累加 的 结果 。 下 图 演示 了 如 何 把 A7h 
加 到 该 地 址 。 


OPOh: (O09h: 


1004H 地 扯 处 的 字 
Oh | 区 太 本 


0003h 李 训 册 n 直 处 的 字 站 加 到 | 。 gooc | 22 | 提起 中 时 计生 


把 累 吉 器 中 的 内 容 保存 


OO: 到 1005h 地 址 外 


当 这 6 条 指令 执行 完毕 之 后 , 存储 器 1004h 和 1005h 地 址 保存 的 16 位 数 与 A7h 乘 以 
1 的 结果 相同 。 因 此 ， 为 了 使 存放 于 该 地 址 的 值 等 于 A7h 与 1Ch 相 屁 的 结果 ， 要 把 这 6 
条 指令 再 反复 执行 27 次 。 为 了 达到 这 个 上 且 的 ， 可 以 在 0012h 地 址 开始 把 这 6 条 指令 连续 
输入 27 次 ; 也 可 以 在 0012h 处 保存 一 个 Halt 指令 ， 然 后 将 复位 键 连续 按 28 次 得 到 最 终 


结果 。 


当然 ， 这 两 种 方式 都 不 是 很 理想 。 它 们 都 要 求 你 做 重复 做 许多 遍 和 烦琐 的 事情 : 输入 
一 系列 指令 或 者 反复 按 复位 键 ， 而 重复 的 次 数 就 等 于 乘 数 。 你 当然 是 不 会 愿意 用 这 种 方 
式 来 进行 16 位 数 乘 法 运算 的 。 
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“| 编码 一 一 隐 驾 在 计算 机 软 硬 件 背后 的 语言 


但 如 果 在 地 址 0012h 处 放置 一 条 Jump 指令 会 怎样 呢 ? 这 个 指令 使 得 计数 器 再 次 从 
0000h 处 开始 计数 。 


O012bh: 转 称 到 0000h 地 址 处 的 指令 


这 的 确 是 一 个 巧妙 的 方法 。 第 一 次 执行 完 指 令 之 后 ， 位 于 存储 器 的 1004h 和 1005h 
地 址 的 16 位 数 等 于 A7h 乘 1， 然 后 Jump 指令 使 下 一 条 指令 从 存储 器 顶部 开始 执行 。 第 
二 次 执行 指令 后 ， 该 16 位 数 等 于 A7h 乘 2， 最 后 其 结果 可 以 等 于 A7h 乘 1Ch。 但 是 ,， 这 
个 过 程 不 会 停止 下 来 ， 它 会 一 直 有 反复 执行 下 去 。 


我 们 需要 的 是 这 样 一 种 Jump 指令 ， 它 只 让 这 个 过 程 重 复 执行 所 需要 的 次 数 ， 这 种 指 
令 就 是 条 件 跳 转 指 令 ， 它 并 不 难 实现 。 要 实现 它 ， 要 做 的 第 一 步 是 增加 一 个 与 进位 锁 存 
器 类 似 的 1 位 锁 存 器 。 该 锁 存 器 被 称 为 零 锁 存 器 (Zero latch )， 这 是 因为 只 有 当 8 位 加 法 
器 的 输出 全 部 为 0 时 ， 它 锁 存 的 值 才 是 1。 


8 位 加 法 器 


志 位 


使 或 非 门 的 输出 为 1 的 唯一 方法 是 其 所 有 的 输入 全 为 0。 与 进位 锁 存 器 的 时 钟 输入 
一 样 ， 只 有 当 Add、Subtract、Add with Carry、Subtract with Borrow 这 些 指令 执行 时 ， 
零 锁 存 器 才 锁 存 1 个 数 ， 该 数 称 做 零 标志 位 (Zero flag )。 注 意 ， 它 是 以 一 种 似乎 是 相 
反 的 方式 工作 的 : 当 加 法 器 的 输出 全 为 0 时 ， 零 标志 位 等 于 1; 当 加 法 器 的 输出 不 全 为 
0 时， 零 标志 位 等 于 0。 


有 了 进位 锁 存 器 和 零 锁 存 器 以 后 ， 我 们 可 以 为 指令 表 新 增 4 条 指令 。 
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Subtract 
Add with Carry 
Subtract with Borrow 


Jump 

Jump If Zero( 零 转移 ) 

Jump If Carry (进位 转移 ) 

Jump If Not Zero( 非 零 转移 ) 
Jump If Not Carry( 无 进位 转移 ) 
Halt 


例如 , 非 零 转移 指令 ( Jump If Not Zero ) 只 有 在 零 锁 存 器 的 输出 为 0 时 才 会 跳 转 到 指 
定 的 地 址 。 换 言 之 ， 如 果 上 一 步 的 加 法 、 减 法 、 进 位 加 法 、 或 者 借 位 减法 等 运算 的 结果 
为 0 时 ， 将 不 会 发 生 跳 转 。 为 了 实现 这 个 设计 ， 只 需要 在 常规 跳 转 命令 的 控制 信号 之 上 
再 加 一 个 控制 信号 : 如 果 指 令 是 Jump If Not Zero， ， 那 4 只 有 当 零 标志 位 是 0 时 ，16 位 计 
数 器 才 被 触发 。 


下 图 中 0012h 地 址 之 后 的 指令 即 两 个 数 相 乘 所 用 到 的 上 表 中 的 所 有 指令 。 


0012bh: 


108 | 把 1003h 地 址 处 的 字 节 装 信 宗 加 器 


把 001Eh 地 址 处 的 字 节 加 到 累加 器 


把 累加 器 的 上 内容 保 存 到 1003h 地 址 处 


如 果 零 标志 位 不 为 0， 则 转移 到 0000h 地 
址 处 


停止 
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第 一 次 循环 之 后 , 位 于 地 址 0004h 和 0005h 处 的 16 位 数 等 于 A7h 与 1 的 乘积 ,这 和 
我 们 的 设计 相符 。 在 上 图 中 ， 地 址 1003h 处 的 字 节 通过 Load 指令 载 入 到 累加 器 ， 该 字 节 
是 1Ch。 把 这 个 数 和 001Eh 地 址 的 字 节 相 加 后 ， 恰 好 还 到 的 是 Halt 指令 ， 当 然 这 是 一 个 
合法 的 数 。FFh 与 1Ch 相 加 的 结果 与 从 1Ch 中 减 去 1 的 结果 相同 ， 都 是 1Bh， 因 为 这 个 
数 不 等 于 0， 所 以 零 标 志 位 是 0，1Bh 这 个 结果 会 存 回 到 1003h 地 址 。 下 一 条 要 执行 的 指 
令 是 Jump If Not Zero,， 零 标志 位 没有 置 为 1, 因此 发 生 跌 转 。 接 下 来 要 执行 的 一 条 指令 位 
于 0000h 地 址 。 


需要 记 住 的 是 , Store 指令 不 会 影响 零 标志 位 的 值 。 只 有 Add、Subtract、Add with Carry、 
Subtract with Borrow 这 些 指令 才能 影响 零 标志 位 的 值 , 因 此 它 的 值 与 最 近 执 行 上 述 某 个 指 
令 时 所 设置 的 值 相同 。 


经 过 两 次 循环 后 ，1004h 和 1005h 地 址 所 保存 的 16 位 数 等 于 A7h 与 2 的 乘积 。1Bh 
与 FFh 的 和 等 于 1Ah， 不 为 0， 因 此 仍然 返回 到 顶部 执行 。 


当 执行 到 第 28 次 循环 时 ，1004h 和 1005h 地 址 保存 的 16 位 数 等 于 A7h 和 1Ch 的 乘 
积 。1003h 地 址 保存 的 值 是 1， 它 和 FFh 相 加 的 结果 是 0， 因 此 零 标志 位 被 置 位 ! Jump If 
Not Zero 指令 不 会 再 跳 转 到 0000h 地 址 , 相反 , 下 一 条 要 执行 的 指令 即 Halt 指令 。 这 样 ， 
我 们 就 完成 了 全 部 的 工作 。 


现在 可 以 断言 ,我 们 一 直 不 断 完善 的 这 组 硬件 构成 的 机 器 确实 可 以 被 称 为 计算 机 
( computer )。 当 然 ， 它 还 很 原始 ,但 毕竟 是 一 台 真 正 的 计算 机 。 条 件 跳 转 指令 将 它 与 我 们 
以 往 设计 的 加 法 器 区 别 开 来 , 能 否 控 制 重复 操作 或 者 循环 (looping ) 是 计算 机 ( computer ) 
和 计算 器 ( calculator ) 的 区 别 。 这 里 演示 了 该 机 器 如 何 用 条 件 跌 转 实现 两 个 数 的 乘法 运算 ， 
用 类 似 的 方法 还 可 以 进行 两 个 数 的 除法 运算 。 而 且 ， 这 不 仅仅 局 限于 8 位 数 ， 它 可 以 对 
16 位 、24 位 、32 位 ， 甚 至 更 高 位 的 数 进行 加 、 减 、 乘 、 除 运算 。 而 且 ， 既 然 它 能 完成 这 
些 运算 ， 那 么 对 于 开平 方 根 、 取 对 数 、 三 角 函 数 等 运算 也 完全 可 以 胜任 。 


既然 我 们 已 经 装配 了 一 台 计 算 机 ， 因 此 可 以 使 用 计算 机 相关 词汇 了 。 


我 们 装配 的 计算 机 属于 数字 计算 机 (digital computer )， 因 为 它 只 处 理 离散 数据 。 
经 还 有 一 种 模拟 信号 计算 机 ( analog computer ), 但 现在 已 经 非常 少见 了 。( 数字 数据 就 是 
离散 数据 ， 即 这 些 数 据 是 一 些 确定 的 离散 值 ; 模拟 数据 是 连续 的 ， 并 且 在 整个 取 值 区 间 
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变化 。) 


一 台数 字 计算 机 主要 由 4 部 分 构成 : 处 理 器 (processor )、 存 储 器 〈memory )， 至 少 
一 个 输入 (input ) 设备 和 一 个 输出 (output ) 设备 。 我 们 装配 的 计算 机 中 , 存储 器 是 64 KB 
的 RAM 阵列 ， 输 入 和 输出 设备 分 别 是 RAM 阵列 控制 面板 上 的 开关 和 灯泡 。 这 些 开 关 和 
灯泡 可 以 让 我 们 向 存储 器 中 输入 数据 ， 并 可 以 检查 运算 结果 。 


除了 上 述 3 种 设备 之 外 的 其 他 设备 都 归 类 于 处 理 器 。 处 理 器 也 被 称 作 中 央 处 理 单元 
( central processing unit ) 或 者 CPU。 更 通俗 的 说 法 是 将 其 称 作 计算 机 的 大 脑 ， 但 本 文 将 避 
免 使 用 这 样 的 词 ， 因 为 我 们 所 设计 的 处 理 器 称 不 上 是 大 脑 〈 今 天 ， 微 处 理 器 这 个 词 使 用 
得 非常 普遍 ， 它 是 一 种 非常 小 的 处 理 器 ， 可 以 通过 本 书 第 18 章 讲 到 的 技术 来 构造 它 。 但 
本 章 中 通过 继电器 构造 的 机 器 无 论 如 何 也 称 不 上 “微小 ”的 )。 

我 们 设计 的 处 理 器 为 8 位 处 理 器 。 累 加 器 的 宽度 为 8 位 , 而 且 大 部 分 数据 通路 都 是 8 
位 的 宽度 。 唯 一 的 16 位 数据 通路 是 RAM 阵列 的 地 址 通路 。 如 果 访 通路 也 采用 8 位 宽度 
的 话 ， 存 储 器 容量 最 多 就 只 有 256 字 节 ， 而 不 再 是 65536 字 节 ， 这 样 处 理 器 的 功能 会 受 
到 很 大 的 限制 。 


处 理 器 包括 若干 组 件 。 毫 无 疑问 累加 器 就 是 其 中 一 个 ， 它 只 是 一 个 简单 锁 存 器 ， 用 
来 保存 处 理 器 内 部 的 部 分 数据 。 在 我 们 所 设计 的 计算 机 中 ，8 位 反 相 器 和 8 位 加 法 器 一 起 
构成 了 算术 逻辑 单元 ( Arithmetic Logic Unit )， 即 ALU。 该 ALU 只 能 进行 算术 运算 ， 最 
主要 的 是 加 法 和 减法 运算 。 在 更 加 复杂 的 计算 机 中 (我 们 会 在 后 面 的 章节 看 到 )，ALU 还 
可 以 进行 逻辑 运算 ， 比 如 “与 ”( AND ),，“ 或 ”( OR ),，“ 异 或 ”( XOR ) 等 。16 位 的 计数 
器 被 称 做 程序 计数 器 (PC，Program Counter )。 


我 们 的 计算 机 是 由 继电器 、 电 线 、 开 关 ， 以 及 灯泡 构造 而 成 的 ， 这 些 东西 都 叫做 硬 
件 (hardware )。 与 之 对 应 ， 输 入 到 存储 器 中 的 指令 和 数值 被 称 做 软件 〈software )。 之 所 
以 把 “ 硬 ” 改 成 了 “ 软 ”， 是 因为 相对 于 硬件 而 言 ， 指 令 和 数据 更 容易 修改 。 


当 我 们 在 计算 机 领域 进行 讨论 时 ,“ 软 件 ” 这 个 词 几乎 与 “计算 机 程序 ”( computer 
program )， 或 “程序 ”(program ) 等 术语 是 同 义 的 ， 编 写 软件 也 称 为 计算 机 程序 设计 
( computer programming )。 我们 确定 用 一 些 指令 让 计算 机 实现 两 个 数 相 乘 的 过 程 就 是 在 进 
行 计算 机 程序 设计 。 
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通常 ， 在 计算 机 程序 中 ， 我 们 能 够 把 代码 〈 即 指令 本 身 ) 和 数据 〈 即 代码 要 处 理 的 
数 ) 区 别 开 。 但 有 时 它们 之 间 的 界限 也 不 是 很 明显 ， 比 如 Halt 指令 (FFh ) 就 可 以 有 两 种 
功能 ， 除 了 作为 代码 时 表示 停止 执行 外 还 能 代表 数值 -1。 


计算 机 程序 设计 有 时 也 被 称 做 编写 代码 ( writing code )， 或 编码 ( coding )， 也 许 你 经 
常会 听 到 “我 整个 假期 都 在 编码 ”,“ 我 一 直 干 到 今天 早上 , 敲 出 了 很 多 行 代码 ”。 计 算 机 
程序 设计 人 员 有 时 也 被 称 做 编码 员 ( coders )， 尽 管 有 些 人 可 能 认为 这 是 一 个 贬义 词 。 程 
序 员 更 喜欢 被 别人 称 做 “软件 工程 师 ”( software engineers )。 


能 够 被 处 理 器 响应 的 操作 码 〈 比 如 Load 指令 和 Store 指令 的 代码 10h 和 11h )， 称 做 
机 器 码 (machine codes )， 或 机 器 语言 (machine language )。 计 算 机 能 够 理解 和 响应 机 器 
码 ， 其 原理 和 人 类 能 够 读 写 语言 是 类 似 的 ， 因 此 这 里 使 用 了 “语言 ”来 描述 它 。 

一 直 以 来 ,我们 都 在 使 用 很 长 的 短语 来 引用 机 器 所 执行 的 指令 ， 比 如 Add with Carry 
间 令 。 通 常 而 言 ， 机 器 码 都 分 配 了 对 应 的 简短 助 记 符 ， 这 些 助 记 符 都 用 大 写字 母 表示 ， 
包括 2 个 或 3 个 字符 。 下 面 是 一 系列 上 述 计算 机 大 致 能 够 识别 的 机 器 码 的 助 记 符 。 


Load (加 载 ) 

Store ( 保存 ) 

Add( 加 法 ) 

Subtract (减法 ) 

Add with Carry( 进位 加 法 ) 
Subtract with Borrow ( 借 位 减法 ) 


Jump (转移 ) 

Jump If Zero( 零 转移 ) 

Jump If Carry( 进位 转移 ) 

Jump If Not Zero ( 非 零 转移 ) 
Jump If Not Carry (无 进位 转移 ) 


当 这 些 助 记 符 与 另外 一 对 短语 结合 使 用 时 ， 其 作用 更 加 突出 。 例 如 ， 对 于 这 样 一 条 
长 语句 “把 1003h 地 址 处 的 字 节 加 载 到 累加 品 ”， 我 们 可 以 用 如 下 简洁 的 句子 替代 : 


LOD A, [1003h] 
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位 于 助 记 符 右 侧 的 A 和 [1003b] 称 为 参数 ( argument )， 它 们 是 这 个 Load 指令 的 操作 
对 象 。 参 数 由 两 部 分 组 成 , 左边 的 操作 数 称 为 目标 ( destination ) 操作 数 (A 代表 累加 器 )， 
右边 的 操作 数 称 为 源 〈source ) 操作 数 。 方 括号 “[]” 0 是 , 1003h 
这 个 数值 ， 而 是 位 于 存储 器 地 址 1003h 的 数值 。 


类 似 的 ， 指 令 “ 把 001Eh 地 址 的 字 节 加 到 累加 器 " ， 可 以 简写 为 : 

RDD A, [0010Eh] 

指令 “把 累加 器 中 的 内 容 保存 到 1003h 地 址 ”， 可 简写 为 : 

STO [1003h], A 

注意 ， 在 上 面 的 语句 中 ， 目 标 操作 数 〈 Store 指令 在 存储 器 中 的 位 置 ) 仍然 在 左边 ， 
源 操 作 数 在 右边 。 这 就 决定 了 累加 器 中 的 内 容 必须 要 保存 到 存储 器 的 1003h 地 址 。“ 如 果 
零 标 志 位 不 是 1 则 跳 转 到 0000h 地 址 处 ”这 个 元 长 的 语句 可 以 简明 地 表示 为 : 


JNZ 0000h 


注意 ,这 里 没有 使 用 方 括号 ， 这 是 因为 跳 转 指令 要 转移 到 的 地 址 是 0000h， 而 不 是 保 
存 于 0000h 地 址 的 值 ， 即 0000h 地 址 就 是 跳 转 指令 的 操作 数 。 


用 缩写 的 形式 表示 指令 是 很 方便 的 ， 因 为 在 这 种 形式 下 指令 以 可 读 的 方式 顺序 列 出 
而 不 必 画 出 存储 器 的 空间 分 配 情况 。 通 过 在 一 个 十 六 进 制 地 址 后 面 加 一 个 冒号 ， 可 以 表 
示 某 个 指令 保存 在 某 个 特定 地 址 空间 ， 例 如 : 


0000h : LOD A, [1005h] 


下 面 的 语句 表示 了 数据 在 特定 地 址 空 河 的 存储 情况 。 


1000h : 00h, A7h 
1002h: 00hn, lch 
1004h: O00h, O00h 


你 可 能 已 经 注意 到 了 ， 上 面 的 两 个 字 节 都 是 以 逗号 分 开 的 ， 它 表示 第 一 个 字 节 保存 
在 左 侧 的 地 址 空间 中 ， 第 二 个 字 节 保存 在 该 地 址 后 的 下 一 个 地 址 空间 中 。 上 面 的 三 条 语 
旬 等 价 于 下 面 的 这 条 语句 : 


TI000h : 00h, A7h, O00h, iCh, O00h, 00h 
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因此 上 面 讨论 的 乘法 程序 可 以 用 如 下 一 系列 语句 来 表示 : 


0000h : LOD A, [1005h] 
ADD A, [1001h] 
STO [i1005h], A 


LOD A, [1004h] 
ADC A, [1000h] 
STO [1004h], A 


LOD A, [1003h] 
ADD A, [001Eh] 
STO [1003h], A 


JNC 0000h 
001Eh : HLT 
1000h: O00h, A7h 
1002h: 00h，1Ch 
1004h : 00h, 00h 


使 用 空格 和 空 行 的 目的 仅仅 是 为 了 人 们 更 方便 地 阅读 程序 。 


在 编码 时 最 好 不 要 使 用 实际 的 数字 地 址 ， 因 为 它们 是 可 变 的 。 例 如 ， 如 果 要 把 数值 
保存 在 存储 器 的 2000h ~2005h 地 址 空间 中 ， 你 需要 在 程序 中 重复 多 次 写 这 些 语句 。 用 标 
号 (label ) 来 指 代 存 储 器 中 的 地 址 空间 是 个 较 好 的 办 法 。 这 些 标号 是 一 些 简 单 的 单词 , 或 
是 类 似 单词 的 字符 串 。 上 面 的 代码 可 以 改写 为 : 

BEGIN: LOD A, [RESULT + 1] 


ADD A, [NUM1 + 1] 
STO [RESULT + 1], A 


LOD A, [RESULT] 
ADC A, [NUM]1] 
STO {RESULT], A 


LOD A, [NUM2 + 1] 
ADD A, [NEG1] 
STO [NUM2 + 1], A 


JN2 BEGIN 
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NEG1: HLT 

NUM1 : 00h, A7h 
NUM2 : O00h, 1lch 
RESULT: 0O0h, O00h 


注意 , NUM1, NUM2, RESULT 这 些 标号 都 是 指 存储 器 中 保存 两 个 字 节 的 地 址 单元 。 
在 这 些 语句 中 , NUM1+1,，NUM2+1 和 RESULT+1 分 别 指标 号 NUM1, NUM2, RESULT 
后 的 第 二 个 字 节 。 注 意 ，NEG1 (negative one ) 用 来 标记 HLT 指令 。 


最 后 ， 如 果 你 可 能 忘记 这 些 语 句 所 表示 的 意思 ， 那 么 可 以 在 该 语句 后 面 加 注释 
(comment ), 这 些 注释 可 以 用 我 们 人 类 的 自然 语言 表述 , 然后 通过 分 号 与 程序 语句 分 隔 开 。 


BEGIN: LOD A, [RESULT + 1] 


ADD A, [NUM1 + 1] ; 低 字 节 相 加 
STO [RESULT + 1]1, A 


LOD A, [RESULT] 
ADC A, [NUM1] `; 高 字 节 相 加 
STO [RESULT], A 


LOD A, [NUM2 + 1] 
ADD A, [NEG1] ; 第 二 个 数 减 1 
STO [NUM2 + 1], A 


JNZ BEGIN 

NEG1: HLT 

NUMI : 00h, A7h 
NUM2 : 00h，1Ch 
RESULT : 00hn, O00h 


这 里 给 出 的 是 一 种 计算 机 程序 设计 语言 ， 称 为 汇编 语言 (assembly language )。 它 是 
全 数字 的 机 器 语言 和 指令 的 文字 描述 的 一 种 结合 体 。 同 时 它 用 标号 表示 存储 器 地 址 。 人 
们 有 时 候 会 混淆 机 器 语言 和 汇编 语言 ， 这 是 因为 它们 是 对 同一 种 事物 的 不 同 描述 方式 。 
每 一 条 汇编 语句 都 对 应 着 机 器 语言 中 的 某 些 特 定 字 节 。 


如 果 你 想 为 本 章 所 设计 的 计算 机 编写 程序 ， 那 么 可 能 首先 想到 的 是 用 汇编 语言 来 编 
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一 信友 一 隐匿 在 计算 机 本 件 背后 的 户 襄 


写 (在 纸 上 )。 在 你 确定 程序 无 误 并 准备 验证 其 运行 结果 的 时 候 ， 你 需要 手工 对 其 汇编 ; 
这 就 意味 着 要 把 每 一 条 汇编 语句 转换 成 与 之 对 应 的 机 器 语言 ， 这 仍然 要 在 纸 上 操 作 。 完 


成 之 后 ， 你 需要 通过 开关 把 这 些 机 器 码 输入 到 RAM 阵列 中 并 运行 该 程序 , 也 就 是 让 计算 
机 执行 这 些 指令 。 


对 于 学 习 计 算 机 程序 设计 的 人 来 说 ， 应 该 尽早 了 解 “ 错 误 ”( bug ) 这 个 术语 。 当 你 
写 代 码 时 一 一 特别 是 采用 机 器 语言 一 是 非常 容易 出 错 的 。 和 输入 一 个 错误 的 操作 数 已 经 
很 不 妙 了 ， 如 果 输 错 的 是 一 个 指令 代码 的 话 ， 情 况 会 怎样 昵 ? 当 你 准备 输入 10b (Load 
和 令 ) 的 时 候 , 却 输入 了 11h ( Store 指令 )， 造 成 的 后 果 是 : 期 望 的 数据 不 会 被 机 器 加 载 ， 
而 该 地 址 的 数据 还 会 被 累加 器 中 的 内 容 蔡 换 掉 。 


一 些 错误 可 能 导致 意 想 不 到 的 结果 。 假设 你 使 用 Jump 指令 跳 转 到 一 个 地 址 ， 而 该 地 
址 没有 存放 任何 合法 的 指令 , 或 者 你 偶然 误 用 Store 指令 覆盖 了 其 他 指令 ， 类 似 的 情况 都 
有 可 能 发 生 (而 且 会 经 常 发 生 )。 


甚至 上 述 乘法 程序 中 就 存在 着 一 个 错误 。 如 果 你 把 程序 执行 两 次 ， 第 二 次 得 到 的 将 
会 是 A7h 与 256 相 乘 的 结果 ， 并 且 程 序 会 把 这 个 结果 与 第 一 次 运算 的 结果 相 加 。 这 是 因 
为 程序 执行 一 次 之 后 ，1003h 地 址 保存 的 数值 是 0。 当 第 二 次 执行 时 ，FFh 与 这 个 0 相 加 
的 结果 不 是 0， 因此 程序 会 继续 执行 直到 它 变 为 0。 


我 们 已 经 利用 该 机 器 完成 了 乘法 运算 ， 用 类 似 的 方法 也 可 以 进行 除法 运算 。 同 时 ， 
前 面 也 讲 过 ， 利 用 这 些 基 本 功能 还 可 以 进行 平方 根 、 对 数 、 三 角 函 数 等 运算 。 机 器 所 需 
要 的 仅仅 是 能 够 做 加 、 减 法 的 硬件 以 及 利用 条 件 跳 转 指令 执行 代码 的 方法 。 正 如 程序 员 
经 常 挂 在 嘴 边 的 一 句 话 :“ 我 可 以 用 软件 完成 其 他 工作 ”， 这 些 工 作 我 们 都 可 以 编程 实现 。 


当然 , 软件 可 能 是 很 复杂 的 。 有 很 多 专门 讲授 程序 员 如 何 用 算法 (algorithm ) 解决 特 
殊 问题 的 书 ， 本 书 不 打算 讲 这 些 内 容 。 目 前 我 们 一 直 讨 论 的 都 是 自然 数 ， 并 没有 考虑 如 
何在 计算 机 中 表示 十 进 制 小 数 ， 本 书 将 在 第 23 章 讨论 这 个 问题 。 


前 面 不 止 一 次 强调 过 ， 这 些 硬件 部 件 早 在 100 年 前 就 发 明 出 来 了 。 但 是 ， 本 章 所 设 
计 的 计算 机 在 当时 却 并 没有 被 创造 出 来 。 当 继电器 计算 机 在 20 世纪 30 年 代 中 期 被 设计 
出 来 的 时 候 ， 很 多 包含 在 其 中 的 概念 还 并 不 为 人 所 知 ， 直 到 1945 年 左右 世人 才 开 始 慢 慢 
了 解 它们 。 例 如 ， 在 当时 ， 入 们 仍然 尝试 在 计算 机 中 使 用 十 进 制 数 而 不 是 二 进 制 数 ; 而 


入. 250 


且 计 算 机 程序 也 不 是 完全 存储 在 存储 器 中 的 ， 有 时 候 它 们 会 被 保存 在 纸 带 上 。 特 别 是 在 
早期 的 计算 机 中 ， 存 储 器 非常 昂贵 并 且 体积 庞大 ， 不 论 在 100 年 前 还 是 在 今天 ， 用 500 
万 个 电报 继电器 构建 一 个 64 KB 的 RAM 阵列 都 是 令 人 感到 匾 唐 的 事 。 

当 回 顾 完 计算 器 和 计算 机 这 一 段 历 史 ， 让 我 们 展望 一 下 未 来 。 或 许 有 一 天 我 们 会 发 
现 : 没有 必要 建造 一 个 如 此 复杂 的 继电器 计算 机 。 正 像 在 第 12 章 所 讨论 过 的 那样 ， 继 电 
器 最 终 会 被 真空 管 和 晶体 管 这 类 电子 器 件 所 替代 。 或 许 我 们 还 会 发 现 ， 已 经 有 人 创造 出 
一 种 全 新 的 设备 ， 它 的 处 理 器 及 存储 器 的 能 力 与 我 们 所 设计 出 的 不 相 上 下 ,但 是 ， 这 种 
机 器 精致 小 巧 ， 其 至 可 以 放 在 我 们 的 掌心 。 
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从 算盘 到 心 


自古 以 来 ， 人们 为 了 尽量 简化 数学 计算 ， 绞 尽 脑 半 发 明了 很 多 精巧 的 工具 和 机 器 。 
虽然 人 类 的 计数 能 力 与 生 俱 来 ， 但 需要 帮助 是 在 所 难免 的 。 每 个 人 都 是 各 有 所 长 、 各 有 
所 短 ， 所 以 经 常会 遇 到 一 些 自身 无 法 解决 的 问题 。 


在 人 类 社会 早期 ， 人 们 借助 数字 这 种 工具 来 帮助 自己 记录 物品 和 财产 。 包 括 古 希腊 
以 及 美洲 土著 在 内 的 很 多 文化 中 ， 人 们 借助 小 卵石 或 者 谷 粒 进行 计数 。 在 欧洲 ， 这 些 古 
老 的 计数 方式 演变 成 了 计数 板 ， 而 在 中 东 ， 则 演变 成 为 我 们 较为 熟悉 的 由 骨架 和 算 珠 组 
成 的 算盘 ( abacus )， i 


尽管 人 们 通常 将 算盘 与 亚洲 文化 ， 尤 其 是 中 国文 化 联系 到 一 起 ， 但 它 似乎 是 在 公元 1200 
年 左右 由 商人 带 到 中 国 的 。 


很 多 人 不 喜欢 做 乘法 和 除法 ， 但 仍然 有 一 小 部 分 人 对 此 进行 了 一 些 研 究 。 苏 格 兰 数 
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学 家 约翰 纳 皮尔 (John Napier，1550-1617) 就 是 这 小 部 分 人 中 的 一 员 ， 为 了 简化 某 些 
操作 ， 他 发 明了 对 数 。 例 如 了 两 个 数 乘积 就 可 以 简单 地 表示 为 其 对 数 之 和 。 因 此 ， 如 果 要 
得 到 两 个 数 的 乘积 ， 可 以 采取 以 下 步骤 : 首先 在 对 数 表 中 查 出 这 两 个 数 的 值 ， 然 后 将 其 
值 相 加 ， 最 后 在 对 数 表 中 逆向 搜寻 出 其 匀 积 。 


在 随后 的 400 年 时 间 里 ， 一 些 最 伟大 的 思想 家 一 直 致 力 于 建立 对 数 表 这 项 工作 ， 与 
此 同时 ， 另 外 一 些 人 则 设计 出 一 些小 装置 期 望 代 蔡 对 数 表 。 其 中 ， 一 种 带 对 数 刻 度 的 刘 
尺 久负盛名， 它 由 埃 德 蒙 . 甘 特 (Edmund Gunter ，1581-1626 ) 发 明 ， 而 威廉 . 奥 特 
雷 德 ( William Oughtred, 1574- 1660 ) 对 其 进行 了 改进 。1976 年 当 克 重 夫 && 艾 萨 (Keuffel 
让 Esser ) 公司 将 其 制造 的 最 后 一 个 请 尺 赠 送 给 华盛顿 史密斯 索尼 亚 〈( Smithsonian ) 学 院 时 ， 
滑 尺 也 就 宣布 退出 了 历史 有 舞台， 导致 其 退出 的 原因 是 手持 计算 器 的 出 现 。 


纳 皮 尔 发 明了 另外 一 种 由 刻 在 骨头 、 牛 角 、 象 牙 上 的 数字 条 组 成 的 乘法 辅助 器 ， 称 
为 纳 皮 尔 骨 架 (Napier's Bones )。 在 1620 年 左右 ， 威 廉 . 斯 奇 卡 (Wilhelm Schickard ， 
1592-1635 ) 制造 出 了 最 早 的 机 械 计算 器 ， 它 类 似 于 已 经 初步 具备 了 自动 功能 的 纳 皮 尔 骨 
架 。 由 相互 连接 的 车 轮 、 齿 轮 以 及 水 平 仪 组 成 的 一 种 计算 器 几乎 在 同一 时 期 出 现 ， 身 为 
数学 家 以 及 哲学 家 的 布 菜 兹 . 帕斯卡 ( Blaise Pascal，1623-1662 ) 和 哥 特 福 瑞 德 : 武 赫 勒 
姆 . 范 : 莱 布 尼 兹 (Gottfried Wilhelm von Leibniz，1646-1716 ) 是 这 种 机 械 计算 器 的 两 个 
最 主要 的 发 明 者 。 


你 一 定 对 8 位 加 法 器 以 及 能 对 多 于 8 位 的 数 进 行 运算 的 加 法 器 中 的 进位 过 程 记 忆 犹 
新 ， 因 为 这 实在 是 太 烦琐 了 。 起 初 ， 进 位 仅 被 看 做 是 加 法 运算 中 的 “一 碟 小 菜 "， 但 它 却 
成 了 加 法 器 的 核心 问题 。 换 名 话 讲 ， 尽 管 我们 设计 了 一 个 除了 进位 功能 以 外 其 他 功能 都 
俱全 的 加 法 器 ， 这 样 的 器 件 离 “大 功 告 成 ”还 是 很 远 ! 


评价 老式 计算 器 的 一 个 关键 是 其 进位 处 理 能 否 成 功 ， 例 如 帕斯卡 的 设计 ， 他 的 进位 
机 制 禁止 进行 减法 和 运算， 在 进行 减法 运算 时 ， 采 用 的 是 加 上 9 的 补 数 的 方式 (在 第 13 章 
中 介绍 过 )。 直 到 19 世纪 后 半 叶 ， 走 正 意义 上 的 机 械 计 算 器 才 得 以 出 现 并 为 人 们 所 使 用 。 


约瑟夫 : 玛丽 ' 杰 硅 德 (Joseph Marie Jacquard，1752-1834 ) 发 明 的 一 种 奇妙 的 自动 
织 布 机 对 计算 的 历史 产生 了 深远 的 影响 ， 其 程度 甚至 不 亚 于 其 在 纺织 行业 产生 的 影响 。 
杰 奎 德 织 布 机 ( 大 约 于 1801 年 出 现 ) 使 用 打 孔 的 金属 卡片 〈 很 像 钢 琴 上 面 的 金属 卡片 ) 
控制 织物 上 的 图 案 。 杰 奎 德 使 用 了 大 约 1 万 张 卡片 完成 了 一 幅 杰 作 ， 那 就 是 用 黑白 线 织 
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成 的 自画像 。 


在 18 世纪 (直到 20 世纪 40 年 代 )， 计 算 机 就 好 比 一 个 以 计算 维持 生计 的 人 ， 而 计 
算 能 力 就 好 比 计算 机 的 生命 线 。 在 这 个 用 天 上 星辰 进行 航海 导航 的 时 期 ， 经 常 要 用 到 对 
数 表 ， 而 三 角 函 数 表 对 航海 导航 也 非常 重要 。 此 外 ， 如 果 你 想 要 发 表 新 数学 表 ， 就 需要 
使 用 许多 台 计 算 机 ， 让 它们 一 起 工作 ， 最 后 将 所 有 的 结果 汇总 成 一 张 表 。 当 然 ， 从 初始 
计算 到 设置 打印 最 终结 果 ， 每 一 个 阶段 都 可 能 会 出 现 意 想不到 的 错误 。 


为 了 消除 数学 表 中 错误 ， 英 国 数学 家 和 经 济 学 家 查尔斯 . 巴 
贝 芝 (Charles Babbage，1791-1871， 见 右 图 ) 勤奋 工作 ， 他 和 塞 
纱 尔 . 莫 尔 斯 ( Samuel Morse ) 差不多 是 同时 代 的 人 。 


在 那个 时 期 ， 数 学 表 ( 例如 对 数 表 ) 并 没有 计算 表 中 每 一 项 
的 确切 对 数值 ， 因 为 那样 做 将 耗费 太 多 时 间 。 取 而 代 之 的 方法 是 
sm 攻 ”选择 性 的 对 数 计算 ， 即 选取 一 些 数字 进行 对 数 计算 ， 而 对 于 介 于 
这 些 数字 之 间 的 数 的 对 数 则 采用 插 补 法 进行 填充 , 即 差分 法 ( differences ), 通过 相对 简单 
的 计算 求 得 结果 。 


大 约 在 1820 年 ， 巴 贝 芝 认为 他 可 以 设计 制造 一 台 可 以 自动 建 表 ， 甚 至 可 以 自动 设置 
打印 类 型 的 机 器 ， 这 种 机 器 可 以 完全 消除 上 述 错误 。 因 此 他 设想 出 了 差分 机 (Difference 
Engine )， 从 本 质 上 讲 差分 机 是 一 个 大 型 机 械 加 法 器 。 在 差分 机 中 ， 多 位 的 十 进 制 数 通 过 
可 以 暑 合 在 10 个 不 同位 置 的 轮子 表示 ， 而 负数 用 10 的 补 数 来 表示 。 尽 管 早期 一 些 模型 
表明 巴 贝 芝 的 设计 是 完全 可 行 的 ， 而 且 他 也 获得 了 英国 政府 的 一 些 资金 支持 ( 当然 不 是 
很 多 )， 但 差分 机 却 从 来 没有 完成 过 ,在 1833 年 ， 巴 贝 芝 放弃 了 这 项 工作 。 


可 正在 那个 时 候 ， 巴 贝 艺 有 了 一 个 更 好 的 想法 ， 那 就 是 解析 机 ( Analytical Engine )， 
他 的 后 半生 一 直 都 在 不 断 重 复 地 设计 与 修改 (其 间 还 制作 过 几 个 小 模型 以 及 部 分 构件 ) 
这 个 机 器 ， 直 到 其 生命 的 尽头 。 解 析 机 是 19 世纪 最 接近 于 计算 机 的 器 件 ， 在 巴 贝 芝 的 设 
计 中 ,解析 机 包含 一 个 存储 部 件 ( 类 似 于 现在 存储 器 的 概念 ) 和 一 个 运算 部 件 ( 类 似 于 
算术 逻辑 单元 )。 乘 法 可 以 通过 重复 的 加 法 运算 求解 ， 同 样 的 ， 除 法 可 以 通过 重复 的 减法 


解析 机 最 令 人 着 迷 的 地 方 在 于 ， 可 以 使 用 改造 的 杰 奎 德 织 布 机 中 的 卡片 来 编程 。 正 
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如 奥 十 斯 塔 .' 艾 达 : 拜 伦 ( Augusta Ada Byron，1815-1852 )， 即 拉 弗 雷 斯 女 伯爵 对 解析 机 
的 评价 ( 这 人 句 话 出 于 她 翻译 的 一 篇 由 意大利 数学 家 撰写 的 关于 巴 贝 芝 解 析 机 的 文章 ) “我 
们 可 以 肯定 地 说 ， 正 如 杰 奎 德 提花 织 布 机 织 出 了 花 斩 和 树叶 ， 解析 机 编织 出 了 代数 的 结 
构 模 型 。” 


巴 贝 世 大 概 是 第 一 个 意识 到 条 件 跳 转 在 计算 机 中 重要 性 的 人 ， 关 于 这 个 问题 ， 奥 古 
斯 塔 . 艾 达 曾 写 下 这 样 -一段 话 “ 操 作 循环 〈cycle )， 应 该 这 样 去 理解 : 


它 意 味 着 某 个 操作 集 (set of operations ) 重复 执行 的 次 数 不 止 一 次 。 它 的 
次 数 可 以 是 仅仅 两 次 或 者 是 无 限 次 ， 但 它们 实际 上 都 是 组 成 操作 集 的 操作 被 重 
复 执 行 了 。 在 很 多 实例 的 分 析 中 ， 我 们 经 常会 看 到 由 一 个 或 多 个 循环 构成 的 重 
复 组 群 (recurring group )， 也 就 是 循环 中 包含 的 一 个 循环 或 者 多 个 循环 。” 


尽管 在 1853 年 差分 机 最 终 由 一 对 父子 一 一 乔治 ( George ) 和 爱德华 舒 尔 芯 ( Edvard 
Scheutz ) 制造 出 来 ,但 已 经 被 人 们 遗忘 了 好 多 年 的 巴 贝 芝 设 计 的 差分 机 , 直到 20 世纪 30 
年 代 才 因为 人 们 开始 探索 20 世纪 计算 机 的 起 源 时 而 重新 被 提起 。 那 时 ， 巴 贝 芝 所 做 的 一 
些 工 作 已 经 都 被 后 来 的 技术 超越 ， 除 了 超前 的 自动 化 观念 ， 他 所 做 的 工作 对 20 世纪 计算 
机 工程 来 说 几乎 没有 可 以 利用 的 。 
计算 史上 另 一 个 转折 点 源 于 美利坚 合众国 宪法 第 一 条 第 二 款 。 这 一 款 其 中 要 求 每 10 
进行 一 次 人 口 普查 。1880 年 的 人 口 普查 要 求 登记 居民 的 年 龄 、 性 别 以 及 国籍 信息 ， 每 

一 次 人 口 普查 的 数据 采集 工作 都 要 花费 大 约 7 年 的 时 间 。 


人 口 普查 局 的 官员 们 担心 1890 年 的 人 口 普查 的 数据 采集 和 处 理 可 能 会 花费 10 年 以 
上 的 时 间 , 因此 他 们 研究 了 在 工作 中 使 用 自动 系统 的 可 能 性 ， 本 


由 


并 选择 了 由 赫 尔 曼 ' 霍 尔 瑞 斯 (Herman Hollerith, 1860-1929 ) 
开发 的 机 器 ， 他 曾 在 1880 年 人 口 普查 中 进行 过 相关 工作 。 


霍 尔 瑞 斯 的 设计 需要 使 用 大 小 为 65x3 了 7 寸 马尼拉 


( manila ) 穿孔 卡片 (尽管 霍 尔 瑞 斯 不 了 解 巴 由 芝 是 怎样 在 解 
析 机 中 利用 卡片 编制 程序 的 ， 但 他 对 杰 奎 德 织 布 机 中 如 何 使 
用 卡片 却 非常 熟悉 )。 卡 片上 的 孔 按 24 列 每 列 12 个 位 置 排列 ， 

共计 288 个 位 置 。 这 些 点 代表 了 在 人 口 普查 中 需要 记录 的 一 
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个 人 的 特征 , 人 口 普 查 工 作 人 员 通 过 在 卡片 适当 的 位 置 上 打 L4 英寸 的 方 孔 来 标记 上 述 的 
特征 。 


在 读本 书 时 你 可 能 会 习惯 性 地 想到 二 进 制 编码 ， 而 且 你 或 许 立刻 会 猜想 ， 可 以 利用 
卡片 上 的 288 个 穿孔 来 存储 288 位 的 信息 ， 但 是 卡片 的 使 用 方式 并 非 如 此 。 


举例 来 说 ， 在 纯 二 进 制 系统 中 使 用 的 人 口 普查 卡片 上 应 该 有 一 个 位 置 代表 性 别 ， 在 
该 位 置 穿孔 则 代表 男性 ， 不 穿孔 则 代表 女性 (或 与 此 相反 )。 但 是 在 霍 尔 瑞 斯 设计 的 卡片 
中 使 用 了 两 个 位 置 代表 性 别 ， 其 中 第 一 位 置 穿孔 代表 男性 ， 另 外 一 个 位 置 穿孔 代表 女性 。 
同样 的 ， 人口 普查 工作 者 通过 两 个 穿孔 来 标识 普查 对 象 的 年 龄 ， 第 一 个 穿孔 指定 一 个 以 $ 
年 为 间隔 的 范围 如 0~4，5~9，10~ 14， 等 等 。 第 二 个 穿孔 则 表示 对 象 处 于 该 年 龄 段 
(5 年 ) 中 的 哪 一 年 ， 即 可 推算 出 对 象 的 准确 年 龄 。 对 年 龄 进行 编码 共计 需要 28 个 打 孔 位 
置 ， 而 在 纯 二 进 制 系统 中 只 需要 7 个 位 置 就 可 以 对 0~ 127 的 所 有 年 龄 进行 编码 。 


霍 尔 瑞 斯 在 记录 人 口 普 查 信息 时 没有 中 使 用 二 进 制 系统 是 可 以 理解 的 : 对 于 1890 年 
人 口 普 查 工作 者 来 说 ， 将 年 龄 转换 为 二 进 制 数字 ， 这 个 要 求 太 高 了 。 穿 孔 卡片 系统 不 能 
是 完全 的 二 进 制 系统 ， 这 里 还 有 一 个 实际 的 原因 ， 真 正 的 二 进 制 系统 可 以 产生 (几乎) 
所 有 了 筷 都 被 打 穿 的 情况 ， 这 将 使 得 卡片 极 易 碎 裂 ， 而 且 看 上 去 也 不 美观 。 


可 以 对 人 口 普查 的 数据 做 统计 分 析 或 将 其 制作 成 表格 ( tabulated)。 比 如 ， 你 希望 了 
解 每 一 个 人 口 普查 行政 区 中 居住 着 多 少 人 ， 当 然 ， 人 口 的 年 龄 段 的 分 布 也 是 一 个 比较 令 
人 感 兴趣 的 信息 。 为 了 达到 这 些 目 的 ， 震 尔 瑞 斯 制造 了 制 表 机 ， 它 是 组 合 了 入 工 操 作 以 
及 自动 功能 的 半自动 化 工具 。 操 作 人 员 把 一 个 有 288 个 弹簧 针 的 板子 压 到 每 一 个 卡片 上 ， 
每 一 根 弹 簧 针对 应 于 卡片 上 的 一 个 穿孔 位 置 ， 当 弹 筑 针 与 水 银 池 中 的 水 银 接触 时 ， 形 成 
通路 ， 这 个 电路 触发 电磁 体 即 可 进行 十 进 制 计 数 。 


霍 尔 瑞 斯 在 卡片 分 类 机 上 也 使 用 了 电磁 人体。 例如， 如果 需要 收集 所 统 记 的 每 一 种 职 
业 中 人 员 的 年 龄 分 布 信息 ， 首 先 需 要 将 卡片 按照 职业 进行 分 类 ， 然 后 分 别 对 每 种 职业 中 
人 员 的 年 龄 信息 进行 统计 。 分 类 机 使 用 和 制 表 机 中 一 样 的 手 压 方式 ， 不 同 之 处 在 于 分 类 
机 使 用 的 电磁 体 可 以 将 26 个 间隔 区 域 中 任意 一 个 的 舱 口 打开 。 操 作者 把 对 应 的 卡片 通过 
舱 口 放 入 间隔 区 域 ， 之 后 再 手动 关闭 舱 口 。 


在 1890 年 人 口 普查 中 使 用 这 种 自动 化 技术 的 实验 取得 了 令 人 瞩目 的 成 就 ， 在 这 个 实 
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验 中 总 共 加 工 处 理 了 超过 6200 万 张 卡片 ， 数 据 量 是 1880 年 人 口 普查 的 两 倍 ， 但 时 间 却 
只 用 了 后 者 的 三 分 之 一 ， 自 此 ， 霍 尔 瑞 斯 和 他 的 发 明 闻 名 四 海 。1895 年 ， 他 还 到 访 了 莫 
斯 科 ， 俄 国人 欣喜 地 购买 了 他 的 设备 ， 并 于 1897 年 将 其 首次 应 用 在 俄国 人 口 普 查 中 。 


赫 尔 曼 ' 霍 尔 瑞 斯 此 后 一 发 不 可 收拾 。1896 年 ， 他 创办 制 表 机 公司 ( Tabulating 
Machine Company )， 租 借 并 出 售 其 穿孔 卡片 设备 。 到 1911 年 ， 由 于 公司 的 合并 ， 制 表 机 
公司 更 名 为 计算 制 表 记录 公司 ( Computing-Tabulating-Recording Company )， 或 者 叫做 
C-TR 公司 。 再 到 1915 年 , 托马斯 J .华盛顿 (Thomas J. Watson，1874-1956 ) 成 为 C-TR 
公司 的 总 裁 ， 他 在 1924 年 将 公司 的 名 字 更 改 为 国际 商业 机 器 公司 ( International Business 
Machines Corporation )， 即 了 了 M。 


到 1928 年 , 在 1890 年 人 口 普 查 中 最 初 使 用 的 卡片 逐渐 演变 为 著名 的 IBM 卡片 ,“do 
not spindle, fold, or mutilate”,， 这 种 卡片 有 80 列 12 行 , 使 用 了 将 近 50 年 , 其 至 在 其 后 期 ， 
还 有 人 把 它们 叫做 霍 尔 瑞 斯 卡片 。 关 于 这 些 卡 片 的 遗留 问题 将 在 第 20、21 和 24 章 中 进 
一 步 的 讲述 。 


进入 到 20 世纪 之 前 ， 让 我 们 重新 审视 一 下 19 世纪 这 一 百年 。 因 为 主题 所 限 ， 本 书 
更 多 的 关注 的 是 数字 性 质 的 发 明 ， 其 中 包括 电报 、 盲 人 用 点 字 法 、 巴 贝 芝 机 器 ， 以 及 震 
尔 瑞 斯 卡片 。 而 在 与 数字 概念 以 及 相关 设备 打交道 时 ， 你 会 发 现 整个 世界 缘 为 数字 。 但 
是 ，19 世纪 的 发 现 和 发 明确 切 的 来 讲 不 是 数字 的 。 实 际 上 ， 通 过 感官 所 认识 的 大 自然 中 
只 有 很 少 一 部 分 是 数字 的 ， 更 多 的 时 候 表 现 为 不 可 分 割 的 整体 。 


尽管 霍 尔 瑞 斯 在 他 的 制 表 机 以 及 分 类 机 中 使 用 了 继电器 (relays )， 但 是 人 们 直到 
20 世纪 30 年 代 中 期 才 开 始 用 继电器 来 构建 计算 机 它们 最 终 被 叫做 机 电化 
(electromechanical ) 计算 机 。 在 这 些 机 器 中 使 用 的 继电器 不 同 于 一 般 的 电报 继电器 ， 后 者 
的 主要 作用 是 为 了 完善 电话 系统 的 路 由 控制 。 

早期 的 继 电 式 计算 机 与 上 一 音 中 的 继 电 式 计算 机 不 是 同一 个 概念 (我 们 随后 会 学 到 ， 
从 20 世纪 70 年 代 开 始 ， 这 种 继 电 式 计算 机 依靠 微 处 理 器 进行 计算 )。 需 要 特别 说 明 的 一 
点 ， 尽 管 现 代 计 算 机 内 部 使 用 二 进 制 数 ， 但 早期 的 继 电 式 计 算 机 并 非 如 此 。 

我 们 的 继 电 式 计算 机 与 早期 的 继 电 式 计 算 机 存在 另外 一 个 不 同 点 ， 那 就 是 在 20 世纪 
30 年 代 ， 没有 人 能 够 疯狂 到 用 继电器 制造 出 524,288 位 的 存储 器 ! 资金 的 花费 、 空 间 的 
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占用 和 能 源 的 耗费 使 得 制造 如 此 大 的 存储 器 变 得 不 大 可 能 。 可 得 到 的 极 少 存储 器 也 只 用 
来 存储 中 间 结 果 ， 而 程序 本 身 则 存储 在 一 些 物理 媒介 上 面 ， 例 如 带 穿 孔 的 纸 带 。 实 际 上 ， 
将 代码 和 程序 放 入 到 存储 器 进行 处 理 是 后 来 发 明 的 做 法 。 


下 面 按时 间 顺 序 进行 介绍 ， 第 一 台 继 电 式 计算 机 由 康 拉 德 。 楚 泽 (Conrad Zuse， 
1910-1995 ) 制造 ，1935 年 还 是 工科 学 生 的 他 在 其 父母 位 于 柏林 的 家 中 制造 了 这 人 台 机 器 。 
这 台 机 器 中 使 用 了 二进制 数 ， 但 其 早期 的 版 本 中 使 用 的 是 机 械 存储 器 而 非 继电器 。 楚 泽 
使 用 老式 35 毫米 电影 胶片 进行 穿孔 ， 然 后 在 上 面 编制 程序 。 


1937 年 ， 贝 尔 电 话 实验 室 ( Bell Telephone Laboratories ) 的 乔治 ， 史 提 必 北 〈 George 
Stibitz，1904-1995 ) 将 一 对 电话 继电器 带 回 了 家 中 ， 并 在 他 厨房 的 桌子 上 连接 了 一 个 1 
位 加 法 器 ， 后 来 他 妻子 将 其 称 之 为 人 机 器 (及 是 厨房 “kitchen” 的 头 一 个 字母 )， 这 个 实 
验 促 使 1939 年 贝尔 实验 室 中 复数 计算 机 的 诞生 。 


同一 时 期 ， 哈 佛 大 学 研究 生 堆 华 德 艾 肯 (Howard Aiken，1900-1973 ) 要 寻找 做 大 
量 的 重复 计算 的 方法 ， 而 正 是 他 的 这 一 需求 促使 哈佛 大 学 与 IBM 合作 ， 并 最 终 在 1943 
年 创造 出 一 台 自 动 连续 可 控 计 算 机 ( Automated Sequence Controlled Calculator ，ASCC )， 
也 就 是 闻名 于 世 的 Harvard Mark I。 这 是 第 一 台 可 以 打印 表格 的 数字 计算 机 , 它 最 终 将 查 尔 
斯 : 巴 贝 芝 的 梦想 付 诸 于 现实 。Mark II 是 最 大 的 继 电 式 计算 机 , 使 用 了 13,000 个 继电器 。 
哈佛 大 学 计算 机 实验 室 当时 的 主任 是 艾 表 ， 也 正 是 他 讲授 了 计算 机 科学 的 第 一 次 课 。 


对 于 构造 计算 机 来 说 ， 继 电器 不 是 最 完美 的 设备 ， 因 为 它们 是 机 械 性 的 ， 利 用 金属 
片 的 弯曲 和 伸 直 状态 进行 工作 ， 耐 频繁 的 工作 可 能 导致 其 断裂 ， 另 外 如 果 接 触 点 之 间 有 
污垢 或 者 卡 住 纸 届 ， 也 会 导致 继电器 失效 。1947 年 发 生 了 一 件 著 名 的 事故 ， 人 们 从 Mark 
芽 寺 算 机 的 一 个 继电器 中 发 现 了 一 只 飞 蛾 。 格 荔 丝 : 英 瑞 ' 赫 柏 ( Grace Murray Hopper， 
1906-1992 ) 于 1944 加 入 了 艾 表 的 团队 ， 日 后 成 为 了 计算 机 编程 语言 领域 非常 著名 的 人 
物 。 他 将 上 面 提 到 的 那 只 飞 蛾 用 带子 绑 在 计算 机 日 志 (1logbook ) 上 , 并 在 其 边 上 注 明 “第 
一 个 被 发 现 的 有 生命 的 bug”。 


真空 管 (vacuum tube ) 是 一 种 可 以 替代 继电器 的 元 件 ， 它 是 由 约翰 安 布 罗斯 、 弗 
莱 明 (John Ambrose Fleming, 1849-1945 ) 和 李 . 德 . 福 雷 斯 特 ( Lee de Forest，1873-1961 ) 
在 进行 无 线 电 通信 连接 研究 时 开发 出 来 的 。 到 20 世纪 40 年 代 ， 真 空 管 已 经 被 广泛 应 用 
于 放大 电话 信号 ， 实 际 上 ， 那 时 几乎 每 一 个 家 庭 都 拥有 一 台 带 有 发 光 二 极 管 可 控 收 音 机 ， 
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它们 能 放大 无 线 信 号 ， 并 且 把 它们 变 成 还 原 为 人 们 能 听见 的 声音 。 真 空 管 同样 可 以 通过 
连接 成 与 门 、 或 门 、 与 非 门 ， 以 及 与 或 门 一 -这 一 点 很 像 继 电器 。 


究竟 是 由 继电器 还 是 由 真空 管 组 成 这 些 逻 辑 门 并 不 重要 ， 重 要 的 是 这 些 迎 辑 门 可 以 
被 装配 组 合成 加 法 器 、 选 择 器 、 解 码 器 、 触 发 器 ， 以 及 计数 器 。 不 论 真 空 管 何 时 取代 继 
电器 ， 前 面 章节 中 讲述 的 关于 基于 继电器 部 件 的 一 切 同样 是 有 效 的 。 


真空 管 同样 存 在 自身 的 问题 ， 比 如 ， 价 格 昂贵 、 耗 电量 大 ， 以 及 产生 的 热量 太 多 。 
可 是 ， 其 最 大 的 问题 是 真空 管 最 终 会 被 烧 坏 ， 如 同人 活 一 世 一 样 ， 是 无 法 改变 的 事实 。 
那 时 ， 拥 有 真空 管 收音 机 的 人 们 习惯 于 定期 更 换 真 空 管 ， 而 电话 系统 设计 时 有 很 多 元 余 
的 真空 管 ， 所 以 一 个 真空 管 的 报废 有 时 并 不 是 什么 大 事 ( 不 管 怎样 ， 人 们 不 会 期 待 电话 
系统 是 完美 无 瑕 的 )。 可 是 在 计算 机 中 ， 当 一 个 真空 管 伐 坏 时 并 不 可 能 立刻 被 检测 到 ， 此 
外 ， 一 台 计 算 机 拥有 数量 巨大 的 真空 管 ， 按 统计 学 来 分 析 ， 每 隔 几 分 钟 就 会 烧 坏 一 个 。 


用 真空 管 取代 继电器 的 最 大 好 处 在 于 真空 管 的 状态 可 以 在 百 万 分 之 一 秒 (hs ) 内 发 生 
转变 。 真 空 管状 态 转变 ( 开关 的 打开 与 关闭 ) 的 速度 比 继电器 要 快 1000 倍 ， 继 电器 在 其 
最 好 状态 下 状态 的 转变 也 需要 lms, 即 干 分 之 一 秒 。 十 分 有 趣 的 是 在 计算 机 的 早期 发 展 中 ， 
计算 速度 并 不 是 主要 考虑 的 问题 ， 而 这 个 时 期 的 计算 速度 与 从 纸张 或 者 电影 胶片 中 读 取 
程序 的 速度 有 关 。 由 于 当时 的 计算 机 都 按照 这 种 方式 构建 ， 因 此 采用 真空 管 比 继电器 到 
底 计算 速度 提升 了 多 少 ， 并 不 重要 。 


但 是 在 20 世纪 40 年 代 初 期 , 新 设计 的 计算 机 中 真空 管 开始 取代 继电器 。 到 1945 年 ， 
真空 管 已 经 完全 取代 了 继电器 。 虽 然 继 电器 计算 机 被 称 为 电动 机 械 计算 机 ， 但 真空 管 是 
第 一 台电 子 计算 机 的 基础 。 


在 英国 , 巨 像 ( Colossus ) 计 算 机 ( 1943 年 首次 投入 使 用 ) 用 来 破译 德国 名 为 “Enigma” 
代码 生成 器 产生 的 代码 , 艾 伦 .' M : 图 灵 (Alan M. Turing，1912-1954 ) 为 这 个 项 目 (以 
及 英国 后 来 几 个 的 计算 机 项 目 ) 做 出 了 巨大 贡献 ， 图 灵 撰 写 了 两 篇 非常 有 影响 的 论文 ， 
这 使 他 如 今 成 为 计算 机 领域 的 鼎鼎 大 名 的 人 物 。 第 一 篇 论文 发 表 于 1937 年 ， 首 次 提出 了 
“可 计算 性 ”( computability ) 这 个 概念 ， 用 来 分 析 哪 些 事 情 计 算 机 可 以 做 到 , 哪些 做 不 到 。 
他 为 计算 机 构想 了 一 个 抽象 模型 , 这 就 是 现在 为 人 所 熟知 的 图 灵机 ( Turing Machine )。 图 
灵 第 二 篇 非常 有 名 的 论文 是 关于 人 工 智能 的 ， 在 这 篇 论文 中 他 介绍 了 一 种 测试 机 器 智能 
的 方法 ， 即 现在 为 人 熟知 的 图 灵 测 试 法 ( Turing Test )。 
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在 摩尔 电子 工程 学 院 ( 宾夕法尼亚 大 学 ), J : 普 利 斯 普 : 埃 克 特 (J. Presper Eckert， 
1919-1995 ) 和 约翰 莫 克 利 (John Mauchly，1907-1980 ) 设计 了 ENIAC (Electronic 
Numerical Integrator and Computer， 电 子 数 字 积 分 计算 机 )， 使 用 了 18,000 个 真空 管 并 最 
终 在 1945 年 底 完 成 。 按 全 部 吨位 算 (大 约 30 吨 )，ENIAC 是 曾经 (或 许 以 后 也 是 ) 制造 
出 来 的 最 大 的 计算 机 。 到 1977 年 ， 人 们 可 以 在 Radio Shack 买 到 速度 更 快 的 计算 机 。 埃 
克 特 和 莫 克 利 想 为 计算 机 申请 专利 ， 可 是 却 被 竞争 者 约翰 .V ' 安 塔 纳 索 夫 (Johbn V. 
Atanaso 人 ff，1903-1995 ) 阻 扰 了 ， 他 更 早 一 步 设 计 了 一 台电 子 计算 机 ， 但 它 运 行 得 并 不 顺 
畅 。 


ENIAC 吸引 了 数学 家 约翰 : 冯 ' 诺 依 曼 ( John von Neumann，1903-~ 1957 ) 的 眼球 。 
从 1930 年 开始 ， 出 生 在 匈牙利 的 冯 ' 诺 依 曼 就 定居 美国 。 作 为 一 名 令 公 众 瞩 目的 人 物 ， 
因 其 仅 凭 自己 的 大 脑 就 能 进行 复杂 的 数学 计算 而 闻名 ， 怪 ' 诺 依 曼 当 时 是 普林斯顿 高 级 
研究 院 的 一 名 数学 教授 ,研究 范围 很 广 ， 从 量子 力学 到 游戏 应 用 ， 甚 至 到 经 济 理论 。 


约翰 - 色 . 诺 依 曼 协 助 设计 的 ENIAC 的 后 续 产 品 EDVAC 
( Electronic Discrete Variable Automatic Computer )。 特 别 是 在 
1946 年 与 亚 瑟 .W: 伯 克 斯 ( Arthur W. Burks ) 和 荷 曼 :如 
斯 廷 (Herman H. Goldstine ) 共同 执笔 的 题 为 “电子 计算 器 件 
逻辑 设计 的 初步 分 析 及 讨论 (Preliminary Discussion of the 
Logical Design of an Electronic Computing Instrument }” 的 论文 
中 ,他 描述 了 几 个 EDVAC 比 ENIAC 更 加 先进 的 特点 ,EDVAC 
的 设计 者 们 感觉 到 计算 机 内 部 中 应 当 使 用 二 进 制 数 ， 而 
ENIAC 使 用 的 是 十 进 制 数 。 同 时 他 们 认为 计算 机 中 应 当 拥有 
尽 可 能 大 容量 的 存储 器 , 这 些 存 储 器 应 该 用 来 存 桩 程序 代码 和 程序 执行 中 产生 的 数据 (再 
说 明 一 下 ， 这 些 在 ENIAC 中 都 是 不 能 实现 的 ， 对 于 ENIAC 来 说 ， 编 程 不 过 是 扳 动 开关 
和 插 拔 电线 的 事情 )。 这 些 指令 在 存储 器 中 是 顺序 存放 的 ， 而 且 可 以 由 程序 计数 器 进行 寻 
址 ， 但 允许 条 件 跳 转 。 这 就 是 著名 的 “存储 程序 概念 ”( stored-program concept )。 


这 些 设计 上 的 决策 是 计算 机 历史 中 非常 重要 的 一 个 进化 阶段 ， 现 在 我 们 称 之 为 
“ 怪 ， 诺 依 曼 结构 "”。 上 一 章 中 设计 的 计算 机 就 是 一 个 经 典 冯 ' 诸 依 曼 计 算 机 。 但 是 伴随 
着 冯 : 诺 依 曼 结 构 ， 又 出 现 冯 ' 详 依 曼 瓶 颈 〈von Neumann bottleneck )。 在 冯 ' 诺 依 曼 计 


和 260 


18 ”从 算盘 到 芯片 TT 


算 机 中 ,为 了 执行 指令 通常 需要 花费 大 量 的 时 间 先 将 这 些 指令 从 存储 器 中 取出 来 。 我 们 
仔细 回忆 一 下 ， 第 17 章 中 最 后 设计 的 计算 机 需要 花费 3/4 的 时 间 用 来 取 指 令 。 


在 EDVAC 的 那个 时 期 ， 考 虑 到 成 本 效益 ， 用 真空 管制 造 大 容量 存储 器 是 不 可 行 的 ， 
因此 那 时 提出 了 一 些 临 时 的 替代 方案 。 其 中 一 个 成 功 的 方案 是 “水 银 延 迟 线路 存储 器 ” 
(mercury delay line memory )， 它 使 用 $ 英尺 水 银 真 空 管 ， 在 管子 的 一 端 每 隔 1ys 向 水 银 
发 送 一 个 短 脉冲 ， 这 些 短 脉冲 大 约 需要 lms 到 达 管 子 的 另 一 端 ( 可 以 如 同 检测 声波 一 样 
检测 到 这 些 短 脉冲 ， 并 折 回 开始 端 )， 因 此 一 个 水 银 管 可 以 存储 大 约 1024 位 的 信息 。 


直到 20 世纪 50 年 代 中 期 人 们 才 开 发 出 了 “ 磁 芯 存储 器 ”( magnetic core memory )。 
众多 的 被 磁化 的 小 金属 环 由 电线 串 起 来 组 成 了 磁 心 存储 器 。 每 一 个 小 金属 环 可 以 存储 1 
位 信息 。 磁 芷 存储 器 祝 用 了 很 长 一 段 时 间 才 被 别 的 技术 取代 ， 所 以 常常 会 听见 老 一 辈 程 
序 员 们 把 存储 器 的 访问 过 程 叫做 “访问 磁 芯 ”。 


20 世纪 40 年 代 ， 对 计算 机 本 质 进 行 概念 化 设想 的 并 非 只 有 约翰 冯 : 诺 依 曼 一 人 。 


克 劳 德 . 香农 ( Claude Shannon， 生 于 1916 年 ) 是 另外 一 个 非常 有 影响 力 的 思想 家 。 
在 第 11 章 中 讨论 了 他 1938 年 的 硕士 论文 , 正 是 这 篇 文章 确定 了 开关 、 继 电器 以 及 布尔 代 
数 之 间 的 关系 。 在 1948 年 为 贝尔 电话 实验 室 工作 期 间 ,香农 在 Bell System Technical Journal 
上 发 表 了 一 片 题 为 “通信 过 程 中 的 代数 理论 ”( 4 Mathematical Theory of Communication ) 
的 文章 ， 在 这 篇 文章 中 他 不 仅 将 “位 ”的 概念 介绍 给 了 世界 ， 更 开创 了 一 个 新 的 研究 领 
域 ， 即 著名 的 “信息 论 ”( information theory )。 信 息 论 研 究 的 是 数字 信息 在 有 了 噪声 ( 这 些 
噪声 通常 阻止 信息 的 通过 ) 的 情况 下 传输 ， 以 及 如 何 弥补 因 噪 声 产 生 的 损失 。1949 年 ， 
他 撰写 了 第 一 篇 关于 如 何 编程 可 以 让 计算 机 下 棋 的 文章 ，1952 年 他 设计 了 一 个 通过 继 电 
器 控制 的 机 械 鼠 ， 它 可 以 在 一 个 迷宫 中 记 住 路 径 。 骑 单车 、 变 戏法 这 些 要 宝 也 使 得 香农 
在 贝尔 实验 室 声 名 更 起 。 


诺 博 尔 特 ' 韦 纳 (Norbert Wiener，1894-1964 ) 从 哈佛 大 学 获得 数学 博士 学 位 时 只 有 
18 岁 ,其 撰写 的 Cybernetics, or Control and Communication in the Animal and Machine( 1948 
年 ) 一 书 使 他 闻名 于 世 。 他 使 用 新 创 词汇 “控制 论 ”( cybemetics: 源 于 希腊 语 舵 手 ) 表 
示人 类 和 动物 的 生物 过 程 同 计算 机 和 机 器 人 的 机 械 原理 之 间 的 关系 。 大 众 文化 中 ， 人 们 
普遍 使 用 cyber 作为 前 级 表示 与 计算 机 相关 的 一 切 , 最 著名 的 一 个 词 , 数 百 万 台 计 算 机 通 
过 因特网 相连 被 称 做 “cyberspace”( 网 络 空间 ), 这 个 词 源 于 计算 机 科幻 小 说 作家 威廉 ' 吉 
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布 森 (William Gibson ) 在 1984 年 发 表 的 小 说 Neuromancer 中 “cyberpunk” 一 词 。 


1948 年 ， 埃 克 特 与 莫 奇 利 ( Eckert-Mauchly ) 计算 机 公司 ( 后 来 成 为 雷 明 顿 兰 德 公 司 
一 部 分 ) 开始 开发 第 一 台 商 用 计算 机 一 一 通用 自动 计算 机 ， 或 者 称 为 UNIVAC。 这 台 机 器 
于 1951 年 完成 ， 此 后 就 被 送 到 了 人 口 普 查 局 。UNIVAC 在 网 络 应 用 方面 的 首次 亮相 在 册 
伦比 亚 广播 公司 ， 它 被 用 来 预测 1952 年 的 总 统 选举 结果 。 沃 尔 特 : 克朗 凯特 〈Walter 
Cronkite ) 将 UNIVAC 称 做 “electronic brain”( 电脑 )。 同 样 是 在 1952 年 ，IBM 发 布 了 其 
第 一 个 商用 计算 机 系统 ， 代 号 701。 


自 此 开始 了 漫长 的 公司 和 政府 的 计算 历史 。 尽 管 这 段 历史 很 有 趣 ， 但 我 们 要 追踪 另 
一 段 历史 一 一 如 何 缩减 计算 机 成 本 和 体积 以 及 让 其 走 入 寻常 百姓 家 ， 这 开始 于 1947 年 一 
个 鲜 为 人 知 的 电子 技术 突破 。 


许多 年 以 来 ， 贝 尔 电话 实验 室 是 一 个 让 天 才 们 对 他 们 感 兴趣 的 一 切 事物 进行 研究 的 
地 方 。 非 常 幸运 的 是 ， 他 们 其 中 的 一 些 人 对 计算 机 有 浓厚 的 兴趣 。 上 面 提 到 的 乔治 和 香 
农 就 是 在 贝尔 实验 室 工作 时 对 早期 的 计算 机 发 展 做 出 了 重大 贡献 。 后 来 , 在 20 世纪 70 
年 代 ， 贝 尔 实验 室 成 为 很 有 影响 的 计算 机 操作 系统 UNIX 和 编程 语言 C 的 诞生 地 ， 我 们 
将 在 下 面 章节 中 介绍 。 


当 AT&T ( 美国 电话 电报 公司 ) 正式 将 科学 与 技术 的 研究 同 其 他 的 业务 分 割 时 ， 贝 尔 
实验 室内 部 结构 发 生 了 改变 ,在 1925 年 1 月 1L 日 成 立 了 子 公司 。 贝 尔 公司 的 最 初 目的 是 
发 展 改良 电话 系统 的 相关 技术 ， 幸 和 运 的 是 在 这 种 非常 模糊 的 目标 下 可 以 做 很 多 技术 研究 ， 
但 是 对 于 电话 系统 而 言 ， 一 个 显而易见 的 长 期 目标 是 通过 电线 不 失真 的 传播 语音 信号 。 


从 1912 年 开始 ， 贝 尔 系 统 致 力 于 真空 管 放 大 器 的 研究 ， 为 了 能 让 电话 系统 使 用 真空 
管 ， 对 其 进行 了 相当 数量 的 研究 和 设计 方面 的 改进 。 尽 管 做 了 大 量 的 工作 ， 真 空 管 仍 然 
有 许多 必须 改进 的 地 方 。 真 空 管 体积 太 大 、 耗 能 大 ， 并 且 最 终 会 烧毁 ， 但 是 ， 它 们 在 当 
时 是 唯一 的 选择 。 


1947 年 12 月 16 日 ， 当 贝尔 实验 室 的 两 个 物理 学 家 约翰 . 巴 】 (John Bardeen， 
1908-1991 ) 和 沃尔特 布 兰 坦 ( Walter Brattain，1902-1987 ) 制作 出 另 一 种 放大 器 时 ， 
所 有 的 一 切 都 发 生 了 改变 。 这 种 新 型 的 放大 器 用 一 块 针 (一 种 半导体 元 素 ) 平板 和 一 条 
黄金 薄片 制 成 。 一 周 之 后 ， 他 们 将 这 个 东西 演示 给 他 们 的 老板 威廉 ， 省 克利 (William 
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Shockley，1910-1989 )。 这 就 是 第 一 个 “晶体 管 ”(transistor )， 它 被 一 些 人 称 为 20 世纪 最 
重要 的 发 明之 一 。 

晶体 管 并 不 是 凭空 产生 的 。 因 为 早 在 8 年 前 ， 即 1939 年 12 月 29 日 ， 肖 克利 在 他 的 
笔记 本 上 写 道 “ 今 天 我 突然 想到 ， 使 用 半导体 来 制作 放大 器 从 原理 上 讲 比 使 用 真空 管 更 
为 可 能 。” 在 晶体管 诞生 后 的 几 十 年 里 ， 人 们 不 断 地 完善 它 。1956 年 肖 克 利 、 巴 本 和 布 兰 
坦 “ 因 为 他 们 在 半导体 上 的 研究 以 及 晶体 管 效应 的 发 现 ”获得 了 当年 的 诺 贝 尔 物理 学 奖 。 


在 本 书 的 开始 部 分 探讨 了 导体 和 绝缘 体 。 导 体 因 为 它们 可 以 有 利于 电流 的 通过 而 得 
名 。 铜 、 银 以 及 金 都 是 很 好 的 导体 ， 元 素 周期 表 中 这 三 种 元 素 同属 一 列 并 非 巧合 。 


前 面谈 到 过 ,原子 中 的 电子 分 布 在 原子 核 外 ， 并 围绕 原子 核 运动 。 这 三 种 导体 的 共 
同 特征 是 在 原子 核 最 外 层 都 有 一 个 单独 的 电子 ， 而 这 个 电子 可 以 很 容易 地 与 原子 中 的 其 
他 电子 剥离 , 因此 可 以 自由 移动 形成 电流 。 与 导体 对 应 的 是 绝缘 体 一 一 比如 橡胶 和 塑料 一 
一 几乎 不 能 导电 。 


销 元 素 和 硅 元 素 ( 以 及 一 些 化 合 物 ) 被 称 为 “半导体 ”( semiconductor )， 之 所 以 称 为 
“半导体 ”并 不 是 因为 它们 的 导电 性 能 是 导体 的 一 半 ， 而 是 因为 它们 的 导电 系数 可 以 通过 
多 种 方式 操控 。 半 导体 的 原子 核 在 最 外 层 有 4 个 电子 ， 是 外 层 所 能 拥有 的 最 大 电子 数目 
的 一 半 。 纯 半导体 中 ， 原 子 之 间 形 成 稳定 的 化 学 键 以 及 类 似 金 刚 石 的 结构 。 这 种 半导体 
不 是 良好 的 导体 。 

但 是 , 半导体 可 以 掺 入 一 些 杂 质 , 即 与 某 些 杂质 组 合 。 一 种 类 型 的 杂质 称 做 N 型 (N 
表示 negative ) 半导体 ， 它 们 为 原子 之 间 的 结合 提供 额外 的 电子 。 另 外 一 种 类 型 的 杂质 被 
称 做 P 型 半导体 。 

把 一 个 P 型 半导体 夹 在 两 个 N 型 半导体 之 间 可 以 使 之 成 为 一 个 放大 器 。 这 就 是 著名 
的 NPN 晶体 管 , 其 三 部 分 分 别 为 集 电极 ( collector )、 基 极 (base ), 以 及 发 射 极 (emitter )。 


下 面 是 NPN 晶体 管 原 理 示意 图 。 


集 电极 
发 
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在 基 极 施加 微小 的 电压 就 可 以 控制 非常 大 的 电压 从 集 电极 到 发 射 极 。 如 果 在 基 极 没 
有 施加 电压 ， 那 么 晶体 管 将 不 起 作用 。 


晶体 管 通常 封装 在 直径 为 四 分 之 一 英寸 的 小 金属 钠 中 ， 并 伸 出 三 根 金属 线 ， 外 形 如 
下 图 所 示 。 


晶体 管 开创 了 回 态 电子 器 件 的 时 代 ， 即 指 晶体 管 不 再 需要 真空 而 是 使 用 固体 制造 ， 
尤其 是 使 用 半导体 以 及 当今 最 为 常见 的 硅 来 制造 。 除 了 体积 比 真 空 管 更 小 ， 唱 体 管 需要 
的 电量 更 小 ， 产 生 的 热量 更 少 ， 而 且 持 久 耐 用 。 随 身 携带 一 个 真空 管 收音 机 是 无 法 想象 
的 一 件 事情 。 但 晶体 管 收音 机 不 同 ， 它 可 以 由 一 节 电 池 供电 ， 而 且 不 会 发 泥 。1954 年 ， 
对 于 一 些 幸 运 的 人 来 说 ， 或 许 在 圣诞 节 早 上 打开 礼物 盒 时 能 获得 一 件 可 以 随身 携带 的 晶 
体 管 收音 机 。 德 州 仪器 公司 ， 半 导体 革命 中 一 个 非常 重要 的 公司 ， 制 造 了 第 一 批 可 以 随 
身 携带 的 晶体 管 收音 机 。 


可 是 ， 晶 体 管 真 正 的 商业 应 用 却 始 于 助听器 。 为 了 纪念 亚历山大 格雷 厄 姆 .贝尔 
( Alexander Graham Bell ) 为 礁 入 奉献 毕 生 精 力 , AT&T 公司 允许 助听器 制造 商 无 偿 使 用 蛇 
体 管 技术 。 晕 体 管 电视 机 诞生 于 1960 年 ， 到 现在 电子 管 的 应 用 几乎 已 经 消失 了 ( 可是， 
并 非 完全 消失 ， 一 些 高 保 真 音响 爱好 者 以 及 电子 吉他 弹 奏 者 较 热衷 于 电子 管 设 备 ， 他 们 
更 喜欢 真空 管 放 大 器 产生 的 音质 )。 


1956 年 ， 肖 克利 离开 了 贝尔 实验 室 成 立 了 肖 克 利 半 导体 实验 室 ( Shockley 
Semiconductor Laboratories )。 他 回 到 了 自己 出 生 的 地 方 ,加利福尼亚 帕 罗 奥 图 市 。 他 的 公 
司 是 第 一 个 落户 于 该 地 区 的 大 公司 。 其 他 的 半导体 和 计算 机 公司 立刻 也 在 该 地 区 建立 基 
业 ， 旧 金山 南部 的 这 个 地 区 现在 被 人 称 为 硅谷 〈Silicon Valley )。 


开发 真空 管 的 最 初 目的 是 为 了 放大 电信 号 ,但 是 它们 同样 可 以 应 用 在 逻辑 门 的 开关 
上 ， 作 用 与 晶体 管 一 样 。 下 面 你 将 看 到 非常 类 似 于 继电器 形式 的 由 晶体 管 构 造 的 与 门 。 
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只 有 当 A 和 B 输入 同时 为 1 时 晶体 管 才 可 以 导 通 电流 ， 从 而 输出 为 1。 电 阻 的 作用 是 预 
防 短路 。 

按照 下 图 右边 的 方式 连接 两 个 晶体 管 可 以 组 成 一 个 或 门 。 在 与 门 中 ， 上 端 晶 体 管 的 
发 射 极 连 接 下 端 晶体 管 的 集 电 极 。 在 或 门 中 ， 两 个 晶体 管 的 集 电极 都 与 电压 源 连接 ， 两 
个 发 射 极 相互 连接 。 


和 输入 


使 用 继电器 构造 有 允 辑 门 以 及 其 他 的 部 件 的 方法 对 于 晶体 管 同样 是 有 效 的 。 继 电器 、 
真空 管 以 及 晶体 管 最 初 都 是 为 了 开发 放大 器 设计 的 ， 但 是 通过 相似 方式 连接 可 以 组 成 逻 
辑 门 ， 而 计算 机 则 是 由 这 些 部 件 构 成 的 。1956 年 诞生 了 第 一 台 晶 体 管 计算 机 ， 随 后 的 几 
年 里 ,在 新 型 计算 机 设计 中 电子 管 就 被 淘汰 了 。 

有 一 个 疑问 : 晶体 管 肯定 可 以 使 计算 机 更 加 可 靠 、 体 积 更 小 以 及 需要 的 电量 更 少 ， 
但 晶体 管 可 以 使 计算 机 的 结构 变 得 更 简单 么 ? 


答案 是 否定 的 。 晶 体 管 允 许 在 更 小 的 空间 里 安装 更 多 的 逻辑 门 ， 但 是 你 还 是 要 考虑 
这 些 组 件 之 疗 的 互 连 问 题 。 把 晶体 管 连接 起 来 构造 逻辑 门 ， 与 把 继电器 和 真空 管 连接 起 
来 构造 逻辑 门 一 样 困难 。 在 某 些 方面 来 看 ， 这 更 加 困难 ， 因 为 晶体 管 更 加 小 而 且 不 容易 
被 控制 。 如 果 你 想 用 晶体 管制 造 第 17 章 中 的 计算 机 和 64 KB 的 RAM， 设 计 工 作 的 重要 
部 分 应 当 是 构造 某 种 可 以 放置 所 有 部 件 的 结构 。 而 你 的 大 部 分 的 体力 劳动 是 在 数 百 万 只 
晶体 管 之 中 连接 数 百 万 根 线 ， 这 是 很 乏味 的 。 
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可 是 ,我 们 已 经 发 现 晶体 管 的 某 些 组 合 具 有 特定 功能 ， 可 以 重复 利用 。 一 对 晶体 管 
可 以 连接 成 门 ， 而 门 常常 可 以 连接 成 振荡 器 、 加 法 器 、 选 择 器 ， 以 及 解码 器 。 振 荡 器 可 
以 组 成 多 位 锁 存 器 或 者 RAM 阵列 。 如 果 把 晶体 管 预先 连接 成 常见 的 构件 , 再 用 其 来 组 装 
计算 机 会 更 加 容易 。 


这 种 设想 由 英国 物理 学 家 杰 里 佛 ( Geoffrey Dummer， 生 于 1909 年 ) 在 1952 年 5 月 
的 一 次 演讲 中 提出 ， 他 说 :“ 我 希望 展望 未 来 ,”， 接 下 来 他 提出 了 以 下 观点 : 


“ 随 着 晶体 管 的 出 现 以 及 半导体 研究 的 广泛 开展 ,现在 也 许可 以 设想 将 来 会 
出 现 不 采用 连 线 而 是 由 固体 块 组 成 的 电子 设备 。 这 种 固体 块 可 能 由 绝缘 层 、 慎 
体 层 、 整 流 层 以 及 放大 层 四 个 层次 组 成 ， 将 不 同 层次 的 隔离 区 连接 起 来 即 可 实 
现 电 子 功能 。 


然而 ， 真 正 可 以 使 用 的 产品 还 需要 再 等 上 儿 年 。 


1958 年 7 月 


， 德 州 仪器 公司 的 杰克 ， 基 尔 比 (Jack Kilby， 生 于 1923 年 ) 想到 了 一 


个 可 以 在 一 块 硅 片 制造 出 多 个 晶体 管 、 电 阻 和 其 他 电子 元 件 的 方法 ， 而 他 并 不 知道 杰 里 
佛 预 言 。6 个 月 过 后 ， 也 就 是 1959 年 1 月 ， 罗 伯 特 ' 诺 依 斯 (Robert Noyce，1927-1990 ) 
也 想到 了 类 似 的 方法 。 庄 依 斯 起 初 是 为 肖 克 利 半 导体 实验 室 工作 ,但 在 1957 年 ， 他 与 其 
他 7 位 科学 家 离开 了 肖 克 利 半导体 实验 室 创 办 了 仙 童 ( Fairchild ) 半导体 公司 。 


在 技术 的 发 展 史 中 ， 同 时 产生 一 项 发 明 是 较 常见 的 ， 这 可 能 超出 了 人 们 的 想象 。 尽 
管 基 尔 比比 诺 依 斯 早 6 个 月 发 明了 这 种 设备 ， 而 且 德 州 仪 器 公司 先 于 仙 童 公司 申请 专利 ， 


但 却 是 诺 依 斯 首 5 


获得 了 专利 。 因 此 产生 了 法 律 上 的 纠纷 ， 但 过 了 10 年 后 ， 问 题 才 得 到 


令 双 方 都 满意 的 解决 。 尽 管 基 尔 比 和 谐 依 斯 并 没有 在 一 起 共事 ， 但 今天 他 们 俩 被 称 为 集 
成 电路 ， 或 者 叫做 IC〈 更 通俗 的 说 法 是 芯片 ) 的 共同 发 明 者 。 


集成 电路 需要 经 过 非常 复杂 的 工艺 流程 才 可 以 制造 出 来 ， 包 括 将 硅 片 分 层 ， 然 后 非 
常 精 确 地 挫 入 杂质 以 及 蚀刻 不 同 的 区 域 形 成 微小 组 件 。 开 发 一 种 新 的 集成 电路 尽管 很 昂 
贵 ， 但 可 以 大 量 生产 中 获得 效益 一 一 产量 越 大 ， 价 格 就 越 便宜 。 


实际 上 ， 硅 片 是 薄 而 且 易 碎 的 ， 因 此 它 必 须 被 安全 地 封装 起 来 ， 这 样 不 仅 可 以 起 到 
保护 作用 ， 还 可 以 为 芯片 内 部 的 部 件 与 其 他 芯片 之 间 的 连接 提供 某 种 便利 。 集 成 电路 有 
几 种 不 同 的 封装 方式 , 但 最 为 常见 的 是 采用 矩形 塑料 双 排 直 插 式 (或 称 为 DIP ), 提供 14、 
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16 或 者 40 个 管 脚 。 


上 图 是 一 个 有 16 个 管 脚 的 芯片 。 将 芯片 上 的 四 本 朝 左 放 置 ( 如 图 )， 用 1 到 16 对 管 脚 进 
行 编号 ， 从 左下 角 开 始 ， 环 绕 到 右 端 ， 依 次 为 1~ 16，16 号 管 脚 位 于 左边 最 上 端 。 管 脚 
之 间 的 距离 正好 是 10 英寸 。 


维 观 20 世纪 60 年 代 ， 太 空 项 目 以 及 军备 竞赛 推动 了 早期 的 集成 电路 市 场 的 发 展 。 
在 民用 方面 ， 第 一 台 用 集成 电路 构造 的 商品 是 极点 公司 Zenith ) 在 1964 年 出 售 的 助 听 
器 。1971 年 ， 德 州 仪器 公司 开始 出 售 第 一 批 便携 计算 器 ， 同 年 ， 脉 冲 星 公 司 (Pulsar ) 出 
售 了 第 一 块 电子 手表 (电子 手表 中 的 集成 电路 当然 不 是 刚才 图 示 的 例子 那样 的 )。 随 后 其 
他 利用 了 集成 电路 的 产品 陆续 出 现 。 


1965 年 ， 戈 登 . E . 摩尔 ( Gordon E. Moore， 当 时 在 仙 童 公司 工作 ， 后 来 成 为 英特尔 
公司 的 合伙 创办 人 ) 发 现 从 1959 年 以 后 ， 技 术 在 以 这 样 一 种 方式 发 展 ; 同一 块 芯片 上 可 
以 集成 的 晶体 管 的 数目 每 年 翻 一 倍 。 他 预测 这 种 趋势 将 会 持续 。 真 实 的 发 展 速度 比 摩尔 
的 发 现 稍 慢 一 些 ， 因 此 摩尔 定律 (最 终 命名 ) 被 修正 为 : 每 18 个 月 同一 块 芯片 上 集成 
体 管 数目 就 会 翻 一 倍 。 这 仍 是 一 个 令 人 吃惊 的 速度 ， 它 解释 了 为 什么 刚刚 过 了 几 年 就 家 
用 计算 机 好 像 已 经 过 时 了 。 一 些 人 相信 直到 2015 年 摩尔 定律 仍然 有 效 。 


发 展 的 早期 ， 人 们 常常 谈论 小 规模 集成 电路 ( small-scale integration )， 即 SSI， 指 那 
些 逻 辑 门 小 少 10 个 的 芯片 ， 中 规模 集成 电路 ( medium-scale integration )， 即 MSI ( 包含 
10 到 100 个 逻辑 门 ); 大 规模 集成 电路 ( large-scale integration ),， 即 LSI( 包含 100 到 5000 
个 逻辑 门 )。 随 后 的 术语 为 特大 规模 集成 电路 ( very-large-scale integration )， 即 VLSI( 包 
含 5000 到 50,000 个 逻辑 门 ); 超大 规模 集成 电路 ( super-large-scale integration )， 即 SLSI 
(包含 50,000 到 100,000 个 逻辑 门 ); 超 特大 规模 集成 电路 ( ultra-large-scale integration， 
超过 100,000 个 逻辑 门 )。 


本 章 的 剩余 部 分 以 及 下 一 章 ， 我 想 将 时 间 停留 在 20 世纪 70 年 代 中 期 ， 此 时 正 是 第 
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~ 
| 


一 部 《星球 大 战 》 电 影 发 行 前 的 时 代 ， 而 VLSI 处 于 萌芽 阶段 。 那 时 ， 和 人 们 使 用 几 种 不 同 
的 技术 来 制造 集成 电路 的 组 件 。 有 时 每 一 种 技术 被 称 之 为 一 个 IC 家 族 ， 到 20 世纪 70 年 
代 中 期 ， 有 两 个 “家 族 ” 盛 行 开 来 : TTL 和 CMOS。 


TIL 代表 transistor-transistor logic (晶体管 -晶体 管 逮 辑 )。20 世纪 70 年 代 中 期 ， 如 
果 你 身 为 一 名 数字 电路 设计 师 〈 用 IC 设计 大 规模 电路 )， 那 么 一 本 1.25 英寸 厚 、 由 德州 
仪器 公司 在 1973 年 出 版 的 名 为 The TTL Data Book for Design Engineers(《TTL 工程 师 设 
计数 据 手册 》 以 下 简称 《TTL 数据 手册 》 的 书 将 会 是 你 书桌 上 的 常客 。 这 是 一 本 德州 仪 
器 和 其 他 几 个 公司 出 售 的 TTL 集成 电路 7400 系列 完整 的 参考 书 , 由 之 所 以 这 样 称呼 是 因 
为 这 个 IC“ 家 族 ” 的 每 一 名 “成 员 ” 都 是 以 数字 74 开头 。 

7400 系列 中 的 每 一 个 集成 电路 都 是 由 以 特定 方式 连接 的 预 留 逻辑 门 组 成 。 一 些 芯 片 
提供 简单 的 预 留 的 逻辑 门 ， 设 计 者 可 以 用 它们 来 组 成 更 大 规模 的 组 件 ; 另外 一 些 芯 片 则 
提供 通用 组 件 ， 例 如 : 触发 器 、 加 法 器 、 选 择 器 以 及 解码 器 。 


7400 系列 中 第 一 个 集成 电路 标号 即 为 7400， 在 《TIL 数据 手册 》 中 这 样 描述 它 一 一 
“四 个 双 输 入 正 与 非 门 ”。 这 意味 着 这 个 特殊 的 集成 电路 包含 四 个 双 输 入 与 非 门 。“ 正 ”与 
门 则 是 指 1 对 应 为 有 电压 ， 而 0 对 应 为 没有 电压 。 下 图 是 一 个 14 管 脚 的 芯片 ， 数 据 手册 
中 的 一 张 小 图 显示 了 管 脚 对 应 的 输入 与 输出 。 


ee 


2A 2B 2Y Gnd 


上 面 这 张 图 为 芯片 的 俯视 图 ( 管 脚 在 下 面 )， 小 止 槽 位 于 左边 。 


14 号 管 脚 标注 为 Vcc ,与 符号 V 一 样 ， 用 来 代表 电压 (顺便 说 一 下 ,大 写字 母 V 的 
双 下 标 代表 电压 源 。 下 标的 字母 C 指 晶体 管 的 电压 输入 端 , 即 集 电 极 ，collector )。7 号 管 
脚 标 注 的 GND 代表 接地 ( ground )。 在 特定 电路 中 使 用 的 所 有 集成 电路 都 必须 有 接 电源 
端 与 接地 端 。 
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拿 TTL7400 系列 来 说 ，Vcc 值 必须 介 于 4.75V 和 5.25V 之 间 。 换 名 话 讲 ， 电 压 必须 
在 5SV 土 5% 的 范围 。 电 压低 于 4.75V 时 ， 芯 片 将 无 法 工作 。 而 高 于 5.25V 时 ， 世 片 将 被 
烧 坏 。 即 便 有 一 个 5V 的 电池 ， 那 也 不 能 用 来 对 TTL 进行 供电 ， 因 为 电池 的 电压 不 可 能 
刚好 适合 这 些 芯片 。 通 常情 况 下 ，TTL 需要 从 墙 上 接 入 电源 。 


7400 芯片 中 每 一 个 与 非 门 有 两 个 输入 端 和 一 个 输出 端 ， 且 相互 独立 工作 。 上 一 章 中 
已 经 区 分 了 输入 为 1 (有 电压 ) 或 者 为 0 (无 电压 ) 的 情况 。 实 际 上 ， 与 非 门 的 输入 端 电 
压 可 以 为 0V (接地) 到 5V( Vcc ) 范围 内 的 任 一 值 。TTL 中 ， 当 电压 介 于 0~ 0.8V 任 
一 值 则 可 以 认为 是 逻辑 “0”, 而 介 于 2~ 5V 则 可 以 认为 是 逻辑 “1”。0.8~2V 范围 的 电压 
输入 则 应 当 尽 量 避 免 。 


TTL 的 典型 输出 是 以 0.2V 表示 逻辑 “0”， 以 3.4V 表示 逻辑 “1”。 考 虑 到 电压 值 不 
稳定 ， 有 时 会 有 一 些 波 动 ， 集 成 电路 的 输入 和 输出 端 有 时 不 用 “0” 和 和 “1” 表示， 而 是 
用 “ 低 ” 和 “高 ”表示 。 此 外 ， 有 时 候 低 电压 可 以 表示 边 辑 “1”， 而 高 电压 则 可 以 表示 
逻辑 “0”， 这 种 配置 称 为 “ 负 有 逻辑 "”。7400 芯片 被 称 为 “四 个 双 输 入 正 与 非 门 ”， 而 这 里 
的 “ 正 ” 则 代表 了 上 述 所 讲 的 正 逻 辑 。 


如 果 TTL 的 典型 输出 0.2 V 代表 逻辑 “0”， 而 3.4 V 代表 逻辑 “1”， 那 么 这 个 输出 
电压 确实 是 在 输入 允许 的 范围 内 ， 即 逻辑 “0” 为 0~0.8V， 且 逻辑 “1” 为 2~5V， 
这 就 是 TTL 可 以 隔离 噪声 的 原因 。 逻 辑 “1” 输 出 的 电压 哪怕 下 降 1.4V 也 仍 可 以 作为 
逻辑 “1” 的 高 电压 输入 ,同样 的 ， 人 逻辑 “0” 输 出 的 电压 哪怕 升 高 0.6V 也 仍 可 以 作为 
逻辑 “0” 的 低 电 压 输 入 。 


影响 一 个 集成 电路 性 能 的 最 重要 因素 可 以 认为 是 传播 时 间 ( propagation time )， 也 就 
是 输入 端 发 生变 化 引起 输出 端 发 生 相 应 变化 所 需要 的 时 间 。 


通常 以 纳 秒 来 衡量 芯片 的 传播 时 间 ， 缩 写 为 ngec， 即 ns。1 纳 秒 是 非常 短 的 时 间 。 干 
分 之 一 秒 称 为 毫秒 ， 百 万 分 之 一 秒 称 之 为 微 秒 ， 那 么 十 亿 分 之 一 秒 则 称 为 纳 秒 。7400 芯 
片 中 与 非 门 的 传播 时 间 应 该 保证 小 于 22 ns， 即 0.000000022s。 

感觉 不 到 纳 秒 长 短 的 并 非 只 有 你 一 人 。 地 球 上 的 所 有 人 对 纳 秒 只 有 概念 上 的 理解 ， 
除 此 之 外 别 无 所 有 。 纳 秒 比 人 类 感觉 到 的 任何 事情 都 要 短暂 得 多 ， 以 至 于 永远 无 法 理解 
它 。 任 何 解释 只 会 将 纳 秒 变 得 更 加 难以 捉摸 。 比 如 ， 当 你 拿 着 一 本 离 你 脸 部 距离 为 1 英 
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机 


尺 的 书 时 ， 那 么 纳 秒 可 以 定义 为 光 从 书页 到 你 的 眼睛 的 时 间 ， 但 这 种 解释 可 以 使 你 更 好 
地 认识 纳 秒 么 ? 


然而 ， 纳 秒 使 计算 机 成 为 可 能 。 正 如 在 第 17 章 中 看 到 的 ， 计 算 机 处 理 器 迟钝 地 做 着 
简单 的 事情 一 一 从 存储 器 中 取出 一 个 字 节 放 到 寄存 器 中 , 再 将 两 个 字 节 相 加 , 然后 将 结果 
存放 回 存 储 器 。 迅 速 地 完成 这 些 操 作 是 计算 机 《并非 第 17 章 中 的 计算 机 ， 而 是 当今 使 用 
的 计算 机 ) 能 完成 任何 实际 工作 的 唯一 原因 。 诺 依 斯 说 过 :“ 当 更 好 地 认识 了 纳 秒 后 ， 从 
概念 上 来 讲 计算 机 操作 是 相当 人 简单 的 ”。 

继续 阅读 《TTL 数据 手册 》 会 发 现 书 中 很 多 熟悉 的 小 条 目 。7402 芯片 有 4 个 双 输 入 
或 非 门 ，7404 芯片 有 6 个 反 相 器 ，7408 芯片 有 4 个 双 输 入 与 门 ，7432 芯片 有 4 个 双 输 入 
或 门 ， 以 及 7430 芯片 有 一 个 8 输入 与 非 门 ， 如 下 图 所 示 。 


Ne H 
14 = 13 站 12 


缩写 Nc 表示 无 连接 (no connection )。 


7474 芯片 是 另 一 个 较为 熟悉 的 芯片 。 它 是 一 个 “ 带 预 置 和 清 零 的 双 D 型 正 边沿 触发 
器 "， 如 下 图 所 示 。 


Vec 2Cl 2D 2Ck 2Pre 2Q 2 


1Clr 1CIk iPre 1Q 16 


270 
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《TTL 数据 手册 》 中 甚至 还 宫 括 了 这 个 芯片 中 每 个 触发 融 的 逻辑 图 。 


预 置 


六 
清 季 


有 


ale 


时 钟 


除了 使 用 
手册 》 中 的 逻辑 表 也 稍微 不 同 。 


人 
| 
了 


i 


sa 
ee 


的 是 异 或 门 外 ， 你 会 发 现 上 面 的 这 个 图 与 第 14 章 结 尾 的 


图 很 相似 。《TTL 数据 


表格 中 ，“H” 代 表 高 电 平 ，“L” 代 表 低 电 平 。 


ALL 


然 ， 可 以 将 这 些 想象 成 1 和 0。 在 触发 


器 中 ， 预 置 (Pre ) 和 清 零 输 入 〈 Clr ) 通常 为 0; 这 里 通常 为 1。 


继续 阅读 《TTL 数据 手册 》 会 发 现 ，7483 芯片 是 一 个 4 位 二 进 制 全 加 法 器 ，74151 
是 一 个 8-1 的 数据 选择 器 ，74154 芯片 是 一 个 4-16 的 解码 器 ，74161 芯片 是 一 个 4 位 同步 
二 进 制 计数 器 ， 以 及 74175 芯片 是 一 个 带 清 零 的 4 输入 D 型 触发 器 。 从 上 述 芯 片 中 挑 出 


两 种 可 以 制作 一 个 8 位 锁 存 器 。 


现在 你 应 该 知道 我 是 怎么 想 出 从 第 11 章 中 就 开始 使 用 的 这 么 多 不 同 种 类 的 组 件 的 ， 


这 些 都 是 从 《TTL 数据 手册 》 借 鉴 而 来 。 
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”作为 一 名 数字 电路 设计 工程 师 ， 你 应 当 多 花 点 时 间 看 完 《TTL 数据 手册 》 这 本 书 ， 
使 自己 熟悉 用 得 到 的 TTL 芯片 类 型 。 一 旦 你 熟知 了 使 用 的 工具 ,那么 就 可 以 使 用 TTL 芯 
片 构造 一 台 第 17 章 中 的 计算 机 。 将 芯片 连接 起 来 比 将 一 个 个 的 晶体 管 连接 起 来 容易 得 多 ， 
但 你 可 能 不 会 考虑 使 用 TTL 来 做 64KB RAM 阵列 。1973 年 出 版 的 《TIL 数据 手册 》 中 ， 
列 出 的 容量 最 大 的 RAM 芯片 仅仅 只 有 256x1 位 ,制造 64 KB 需要 2048 个 芯片 ! 对 制造 
存储 器 来 讲 ，TTL 绝 非 最 好 的 技术 。 关 于 存储 器 将 在 第 21 章 中 详细 讨论 。 


或 许 你 想 使 用 更 好 一 点 的 振荡 器 。 只 要 将 TIL 反 相 器 的 输出 连接 到 输入 ， 就 会 获得 
一 个 振荡 器 ， 而 且 其 振荡 频率 更 容易 计算 。 这 种 振荡 器 使 用 石英 晶体 制造 相当 简单 ， 石 
英 晶 体 放 在 带 有 两 个 引线 的 密封 小 扁 缸 中 。 这 些 石英 晶体 的 振荡 频率 在 一 个 特定 的 值 ， 
通常 情况 下 是 每 秒 至 少 振 荡 一 百 万 个 周期 ， 称 1 兆赫 兹 ， 缩 写 为 MHz。 如 果 要 使 用 TTL 
制造 第 17 章 中 的 计算 机 ， 那 么 需要 时 钟 频率 为 10 MHz 才 可 以 使 其 运行 良好 ， 每 条 指令 
执行 时 间 为 400 ns。 当 然 ， 这 比 使 用 继电器 来 做 任何 我 们 所 构想 的 事情 都 要 快 。 


芯片 家 族 中 另 一 位 明星 ( 至 今 仍 是 ) 是 CMOS，CMOS 表示 互补 金属 氧化 物 半 导体 
(complementary metal-oxide semiconductor )。 如 果 你 是 一 名 20 世纪 70 年 代 中 期 的 使 用 
CMOS 集成 电路 进行 电路 设计 的 爱好 者 ， 那 么 可 能 会 使 用 到 一 本 名 为 《CMOS 数据 手册 》 
的 书 作为 参考 源 , 该 书 由 美国 国家 半导体 公司 出 版 , 可 以 在 当地 的 Radio Shack 商店 买 到 ， 
书 中 涵盖 了 CMOS 家 族 中 4000 系列 的 IC 的 信息 。 


TIL 供电 电压 要 求 在 4.75 ~ 5.25V 范围 内 。 而 对 于 CMOS 来 说 , 范围 在 3~ 18V 内 的 
电压 均 可 ， 这 是 非常 灵活 的 。 此 外 ，CMOS 相 比 TTL 需要 更 少 的 能 量 ， 这 使 得 用 电池 运 
行 小 型 CMOS 电路 变 得 可 行 。CMOS 的 缺点 是 速度 慢 ， 比 如 ， 在 供电 电压 为 5 伏 的 情况 
下 ，CMOS 4008 4 位 全 加 器 可 以 保证 的 传播 时 间 只 有 750 ns。CMOS 必 片 的 传播 速度 会 
随 着 电压 提高 而 提高 一 一 10V 时 为 250ns ，15 伏 时 为 190 ns， 但 仍 不 能 与 TTL4 位 加 法 器 
的 24 ns 的 传播 时 间 相 媲 美 《25 年 前 ，TTL 的 速度 与 CMOS 低 功 率 之 间 的 权衡 是 非常 清 
蜥 的， 斗 转 星 移 ,今天 TTL 已 经 拥有 了 低 功率 版 本 而 CMOS 也 有 了 高 速 版 本 )。 


在 实际 应 用 中 ， 芯 片 的 连接 是 在 一 个 塑料 “面包 板 ”( 如 下 图 所 示 ) 完成 的 。 
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A a ae RE A RR Se 人 


下 


pe Re ey A te ny 


每 一 短 行 有 5 个 孔 ， 在 塑料 板 背 面 这 5 个 孔 通 过 电线 相连 。 把 芯片 插入 到 面包 板 中 ， 攻 
片 将 横 跨 在 中 间 长 槽 的 两 人 出， 芯片 的 管 脚 则 分 别 插 到 槽 两 侧 的 孔 里 ， 这 样 芯 片 的 每 一 个 
管 脚 都 会 与 其 他 四 个 孔 里 的 管 脚 相 连接 ,通过 在 孔 之 间 连 接 电线 可 以 实现 芯片 之 间 的 连 
接 。 


使 用 一 种 叫做 “钢丝 包装 ”( wire-wrapping ) 的 技术 可 以 使 芯片 之 间 连 接 更 加 牢固 ， 
芯片 插入 到 带 有 几 个 长 长 的 方 柱 的 插 模 中， 如 下 图 所 示 。 


每 一 个 柱 体 对 应 芯片 的 一 个 管 脚 ， 而 插口 本 身 则 插入 到 事先 穿孔 的 薄板 中 。 在 板子 
的 另 一 面 ， 使 用 特殊 的 钢丝 包装 枪 将 每 一 个 柱 体 周 围 紧 紧 包 上 绝缘 线 。 柱 体 的 直角 边缘 
则 从 绝缘 线 中 破 出， 与 导线 相连 。 


如 果实 际 应 用 中 使 用 集成 电路 制造 一 个 特定 的 电路 ， 那 可 能 会 用 到 “印刷 电路 板 ” 
( printed circuit board )。 很 久 以 前 ， 这 是 集成 电路 爱好 者 做 的 事情 。 这 种 电路 板 上 面 布 满 
了 洞 ， 并 且 被 一 层 薄 铜 片 覆盖 。 基 本 上 ， 可 以 让 防 酸 物质 覆盖 铀 万 上 所 有 你 想 保护 的 地 
方 ， 而 使 用 酸 蚀刻 剩余 的 部 分 ， 接 着 就 可 以 将 集成 电路 的 插口 〈 或 者 是 集成 电路 本 身 ) 
直接 焊接 到 电路 板 上 的 铀 片上 ， 但 由 于 集成 电路 中 存在 很 多 互相 连接 ， 仅 获 盖 一 层 铀 片 
通常 情况 下 无 法 完成 电路 ， 所 以 商业 制造 的 印刷 电路 板 有 多 层 互 连 。 


到 20 世纪 70 年 代 早期 使 用 集成 电路 在 一 块 电 路 板 上 制造 一 个 完整 的 计算 机 处 理 
器 变 得 可 能 ， 实 际 上 这 距离 将 整个 处 理 器 放 入 一 块 芯片 中 ， 只 是 一 个 时 间 问 题 。 昌 然 德 
州 仪器 公司 在 1971 年 为 一 块 单 芯片 计算 机 提交 了 专利 申请 ， 但 真正 制造 出 一 块 这 种 单 片 
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机 芯片 的 荣誉 却 属于 英特尔 公司 ( 英特尔 公司 成 立 于 1968 年 ， 由 仙 童 公司 以 前 的 雇员 罗 
伯 特 诺 伊 斯 和 成 登 摩尔 合伙 创办 )。1970 年 ， 英 特 尔 发 售 了 第 一 款 产品 ， 一 个 可 以 存 
储 1024 位 数据 的 芯片 ， 在 当时 这 是 单一 芯片 中 可 以 存储 的 最 大 位 数 。 


英特尔 在 为 日 本 吉 康 (Busicom ) 公司 生产 的 可 编程 计算 器 设计 芯片 的 过 程 中 ， 决 定 
采取 一 种 不 同 的 方法 。 正 如 英特尔 工程 师 特 德 ， 堆 夫 (Ted Hoff) 说 的 :“ 我 想 让 它 成 为 
一 个 具有 通用 功能 的 计算 机 ， 进 而 可 以 通过 编程 成 为 一 个 计算 器 ， 而 不 是 使 这 个 设备 成 
为 一 个 只 有 一 些 编程 能 力 的 计算 器 ,” 这 导致 了 Intel 4004 的 产生 ， 它 是 第 一 块 “计算 机 
芯片 ”, 或 者 叫做 “ 微 处 理 器 "。1971 年 11 月 ,4040 芯片 已 经 可 以 得 到 使 用 , 它 拥有 2300 
个 晶体 管 (依照 摩尔 定律 ，18 年 后 微 处 理 器 包含 的 晶体 管 数 将 是 这 个 数字 的 4000 倍 , 或 
者 说 是 1000 万 。 这 是 一 个 相当 精确 的 预测 )。 


我 们 已 经 知道 4004 芯片 包含 的 晶体 管 数 目 ， 下 面 是 4004 芯片 另外 三 种 重要 的 特征 。 
自 4004 芯片 开始 ， 在 比较 微 处 理 器 性 能 时 ,通常 采 用 三 个 衡量 标准 。 


第 一 个 标准 : 4004 是 一 个 4 位 微 处 理 器 ,这 意味 着 处 理 器 中 数据 通路 宽度 只 有 4 位 。 
每 次 做 加 、 减 运算 时 ， 它 只 能 处 理 4 位 的 数字 。 对 比 来 看 ， 第 17 章 中 的 计算 机 数据 通路 
是 8 位 ， 因 此 被 称 为 8 位 处 理 器 。 我 们 即将 看 到 8 位 处 理 器 很 快 就 超越 了 4 位 处 理 器 。 
但 技术 并 没有 停止 于 此 ，20 世纪 70 年 代 末 期 ，16 位 徽 处 理 器 已 经 得 到 了 应 用 。 回 想 一 
下 第 17 章 中 的 内 容 ， 以 及 在 8 位 处 理 器 中 进行 两 个 16 位 数 加 法 所 必需 的 指令 码 ， 你 就 
会 欣喜 地 发 现 16 位 处 理 器 带 来 的 优势 。 到 20 世纪 80 年 代 中 期 ，32 位 微 处 理 器 诞生 了 ， 
并 自 此 一 直 作 为 家 用 计算 机 的 主要 处 理 器 。 


第 二 个 标准 : 4004 每 秒 最 大 时 钟 频率 为 108,000 周期 , 即 108 KHz。 时 钟 频率 是 指 连 
接 到 微 处 理 器 并 驱动 它 运 行 的 振荡 器 的 最 大 频率 , 超过 此 时 钟 频率 , 微 处 理 器 将 不 能 正常 
工作 。 到 1999 年 ， 家 用 计算 机 的 微 处 理 器 已 经 达到 了 500 MHz 一 一 比 4004 要 快 5000 倍 。 


第 三 个 标准 : 4004 的 可 寻 址 存储 器 只 有 640 字 节 , 现在 来 看 这 个 数字 小 得 有 点 荒唐 ， 
但 这 与 当时 可 得 的 存储 芯片 的 容量 是 一 致 的 。 下 一 章 中 你 将 会 看 到 ， 两 年 之 中 微 处 理 器 
的 寻 址 能 力 就 达到 了 64 KB, 与 第 17 章 中 计算 机 的 能 力 比 肩 。1999 年 英特尔 生产 的 芯片 
可 以 寻 址 64 TB 的 空间 ， 尽 管 当时 多 数 人 的 家 用 电脑 RAM 容量 还 不 到 256 MB。 


上 述 三 个 数字 指标 并 不 能 影响 一 台 计 算 机 的 计算 能 力 。 比 如 ,4 位 处 理 器 同样 可 以 实 


.274 


18 ”从 算盘 到 忆 片 下 一 
入 | 


现 32 位 数字 加 法 ， 只 不 过 是 将 其 简单 拆 分 为 4 位 的 数 来 进行 。 基 种 意义 上 讲 ， 所 有 的 数 
字 计 算 机 都 是 相同 的 ， 如 果 一 台 处 理 器 从 硬件 上 无 法 做 到 另外 一 台 可 以 做 到 的 事情 ， 那 
么 它 可 以 通过 软件 途径 做 到 ， 最 终 它们 可 以 完成 相同 的 事情 ， 这 是 1937 年 图 灵 在 论文 里 
面 关 于 可 计算 性 的 一 种 定义 。 


然而 ， 速 度 是 处 理 器 之 间 的 根本 不 同 点 ， 同 时 速度 也 是 我 们 使 用 计算 机 的 一 大 原因 。 


最 大 时 钟 频率 (maximum clock speed ) ， 也 称 为 主 频 ， 是 影响 处 理 器 速度 的 决定 性 
因素 之 一 。 时 钟 频 率 决定 了 执行 一 条 指令 所 需要 的 时 间 ， 处 理 器 的 数据 位 宽 也 影响 处 理 
器 的 速度 。 尽 管 4 位 处 理 器 可 以 完成 32 位 数字 的 加 法 ,但 速度 是 不 能 与 32 位 处 理 器 相 
媲美 的 。 然 而 ， 令 人 感到 迷惑 的 是 ， 处 理 器 可 寻 址 存储 器 的 最 大 空间 对 处 理 器 速度 也 是 
有 影响 的 ， 首 先 ， 可 寻 址 存储 器 看 上 去 只 反映 了 处 理 器 的 某 些 能 力 ， 尤 其 是 在 需要 大 容 
量 存储 器 的 前 提 下 进行 数据 处 理 的 能 力 ， 而 与 处 理 器 速度 无 关 。 但 其 实 ， 处 理 器 可 以 利 
用 某 些 存储 器 地 址 去 控制 其 他 的 介质 来 存 取 信息 ， 这 样 就 绕 开 了 存储 器 容量 的 限制 ( 比 
如 ， 假 设 在 特定 的 存储 器 地 址 写 入 一 个 字 节 就 在 一 个 纸 带 上 穿 一 个 孔 ， 而 从 存储 器 中 读 
出 一 个 字 节 等 于 从 纸 带 上 读 取 一 个 孔 一 样 )。 可 是 这 种 处 理 办 法 会 降低 整个 计算 机 的 速度 
一 一 这 就 又 回 到 了 速度 问题 ! 


当然 ， 这 三 个 数字 只 能 粗略 地 反映 微 处 理 器 操作 的 速度 ， 它 们 并 不 能 体现 出 微 处 理 
器 的 内 部 构造 以 及 机 器 指令 代码 的 效率 和 能 力 。 随 着 处 理 器 变 得 越 来 越 复 杂 ， 以 前 通过 
软件 完成 的 任务 都 可 以 在 处 理 器 上 完成 ,我们 将 会 在 后 面 的 章节 中 看 到 这 方面 的 例子 。 


即使 所 有 的 计算 机 具有 相同 的 计算 能 力 ， 即 使 它们 只 能 做 和 图 灵 设计 的 早期 计算 机 
一 样 简 单 的 事情 ， 但 有 一 点 是 无 法 回避 的 ， 那 就 是 处 理 器 的 速度 最 终 决定 了 其 用 途 。 比 
如 那些 表现 比 人 脑 还 慢 的 计算 机 是 毫 无 用 处 的 ， 跟 进一步 来 说 ， 如 果 处 理 器 需要 用 一 分 
钟 来 画 一 由 图像， 那么 对 于 现代 计算 机 而 言 ， 要 想 在 其 屏幕 上 播放 电影 也 是 不 可 能 实现 
的 。 


回 到 20 世纪 70 年代 中 期 , 虽然 4004 有 很 多 局 限 性 , 但 毕竟 只 是 个 开始 。 到 1972 年 4 
月 , 英特尔 发 布 了 8008 芯片 一 一 一 个 时 钟 频 率 为 200 KHz、 可 和 寻 址 空间 为 16 KB 的 8 位 微 
处 理 器 ( 瞧 ， 用 三 个 数字 来 总 结 一 个 处 理 器 是 多 么 简单 的 事 )。 后 来 在 1974 年 5 月 , 英 
特 尔 公 司 和 摩托 罗拉 公司 同时 发 布 了 8008 微 处 理 器 的 改进 版 ， 正 是 两 款 芯 片 改 变 了 整个 
世界 。 
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微 处 理 器 一 一 正 是 它 , 将 计算 机 中 央 处 理 器 的 所 有 构成 组 件 整合 在 一 起 , 集成 在 一 个 
奎 芯 片上 一 一 诞生 于 1971 年 。 它 的 诞生 有 着 很 好 的 开端 : 第 一 个 微 处 理 器 ， 即 Intel 4004 
系列 ， 包 括 了 2300 个 晶体 管 。 到 现在 ， 大 约 三 十 年 过 去 了 ， 家 用 计算 机 的 微 处 理 器 中 的 
晶体 管 数量 也 逐步 逼近 10,000,000 个 。 


从 本 质 上 说 ， 微 处 理 器 实际 上 所 做 的 工作 一 直 没 有 变 。 在 现在 的 芯片 上 ， 新 增 的 几 
百 万 个 晶体 管 所 做 的 很 多 事情 令 我 们 眼前 一 亮 ,但 我 们 正 处 于 微 处 理 器 探索 的 初期 ， 过 
多 的 关心 这 些 当代 的 芯片 并 不 合适 ， 因 为 它们 只 会 分 散 我 们 的 注意 力 而 无 法 帮助 我 们 去 
学 习 与 理解 它 。 为 了 更 清晰 地 认识 微 处 理 器 是 如 何 工作 的 ， 让 我 们 首先 来 看 一 下 最 原始 
的 微 处 理 器 。 


我 们 要 讨论 的 微 处 理 器 出 现 于 1974 年 。 在 这 一 年 ， 英 特 尔 公司 在 4 月 推出 了 8080 
处 理 器 ,摩托 罗拉 公司 一 一 从 20 世纪 50 年 代 生 产 半导体 和 晶体 管 一 一 在 8 月 推出 了 6800 
处 理 器 。 不 仅 如 此 ， 当 年 还 有 其 他 的 一 些微 处 理 器 面世 。 同 年 ， 德 克 萨 斯 仪器 设备 公司 
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(Texas Instruments ) 推出 了 4 位 的 处 理 器 TMS 1000， 它 用 于 多 种 计算 器 、 玩 具 和 设备 ; 
国家 半导体 公司 ( National Semiconductor ) 推出 了 PACE 一 一 首 个 16 位 微 处 理 器 。 但 当 我 
们 回顾 历史 的 时 候 就 会 发 现 ，8080 和 6800 是 两 个 最 具有 重大 历史 意义 的 芯片 。 


英特尔 为 8080 最 初 定 的 价格 为 360 美元 ， 这 个 价格 对 IBM 的 System/360 来 说 是 极 
大 的 讽刺 。Systeny360 是 大 型 机 处 理 系统 , 用 户 大 都 是 一 些 大 公司 ， 售 价 动 辑 儿 百 万 美元 
(今天 ， 你 用 1.95 美元 就 可 以 买 到 一 块 8080 芯片 )。 这 并 不 是 说 8080 可 以 与 System/360 
相提并论 ， 但 在 几 年 之 内 ，IBM 自己 也 关注 起 这 些 非 常 小 的 计算 机 。 


8080 是 一 个 8 位 的 微 处 理 器 ,， 它 包括 6000 个 晶体 管 ， 运 行 的 时 钟 频 率 为 2 MHz, 寻 
址 空间 为 64KB。 摩 托 罗拉 的 6800 (今天 的 售 价 也 是 1.95 美元 ) 包括 4000 个 晶体 管 ， 其 
寻 址 空间 也 是 64 KB。 第 一 个 版 本 的 6800 的 运行 速度 为 1 MHz, 但 摩托 罗拉 于 1977 年 推 
出 了 运行 速度 分 别 为 1.5MHz 和 2 MHz 的 版 本 。 


这 些 芯片 被 称 为 “ 单 芯 片 微 处 理 器 ”( single-chip microprocessors )， 不 太 准 确 的 说 法 
是 “ 单 忆 片 的 计算 机 "。 处 理 器 只 是 计算 机 的 一 部 分 。 除 了 处 理 器 之 外 ， 计 算 机 还 需要 其 
他 一 些 设备 , 至 少 要 包括 一 些 随 机 访问 的 存储 器 (RAM ), 一 些 方便 用 户 把 信息 输入 计算 
机 的 设备 (输入 设备 )， 一 些 使 用 户 能 够 把 信息 从 计算 机 中 读 取 出 来 的 设备 (输出 设备 )， 
以 及 其 他 一 些 能 把 所 有 构件 连接 在 一 块 的 芯片 。 本 书 会 在 第 21 章 详细 介绍 这 些 构 件 。 


现在 ， 让 我 们 来 仔细 研究 一 下 微 处 理 器 本 身 。 当 描述 微 处 理 器 的 时 候 ， 我 们 总 是 习 
惯用 一 些 框图 来 痢 明 其 内 部 的 构件 及 其 连接 情况 。 然 而 ， 在 第 17 章 我 们 已 经 使 用 了 数 不 
清 的 框图 来 描述 它 ， 现 在 我 们 将 观察 微 处 理 器 和 外 部 设备 的 交互 过 程 ， 以 此 来 认识 其 内 
部 的 结构 和 工作 原理 。 换 句 话说 ,为 了 弄 清 微 处 理 器 的 工作 原理 ,我 们 把 它 视 做 一 个 不 
需要 详细 研究 其 内 部 操作 的 黑 盒 。 取 而 代 之 的 方法 是 通过 观测 芯片 的 输入 、 输 出 信号 ， 
特别 是 芯片 的 指令 集 来 理解 微 处 理 器 的 工作 原理 。 


8080 和 6800 都 是 40 个 管 脚 的 集成 电路 .这 些 芯片 最 常见 的 IC 封装 大 约 为 2 英寸 长 ， 
1/2 英寸 宽 ，1/8 英寸 厚 。 
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当然 ， 你 所 看 到 的 只 是 外 部 的 封装 。 其 内 部 的 奎 晶 片 是 非常 小 的 ， 例 如 在 早期 的 8 位 微 
处 理 器 中 ,， 硅 晶片 还 不 到 1/4 平方 英寸 。 外 包装 可 以 保护 内 部 的 硅 晶 户 , 并 且 通 过 管 脚 提 
供 了 处 理 器 的 输入 和 输出 访问 接 入 点 。 下 面 给 出 了 8080 的 40 个 管 脚 的 功能 说 明 图 。 


f 
起 0 < 一 | 1 ~ 4 Ais 
GMD 一 2 39 1 起 4 
Ds 3 38 > Als 
Ts 党 37 i 7 
Ds . 5 36 ~ At 
Dy 6 35 | yp Ag 
Dy Dd 7 34 As 
D» 4—» 8 33 i Ay 
Di < 9 32 As 
Da 二 | 二 3 浊 二 上 < 
_5V -aa lnel 30 As 
| 8080 人 
RESET 一 | 12 29 六 > Ai 
HOLD 一 | 13 28 — +12V 
INT 一 14 27 > Az 
年 一 mi 15 26 i Ai 
INTE < 一 16 25 > Ao 
DEIN < 一 17 24 一 > WAIT 
WR < IS 23 je— READY 
SYNC < 一 19 22 一 9 
+3V 一 一 20 21 全 -> HLDA 
人 


本 书 中 我 们 所 创建 的 所 有 电气 或 电子 设备 都 需要 某 种 电源 来 供电 。8080 的 一 个 特殊 的 
地 方 就 是 它 需要 三 种 电源 电压 : 管 脚 20 必须 接 到 5V 的 电压 ; 管 脚 11 需要 接 到 -5V 的 电 
压 ; 管 脚 28 需 接 12V 的 电压 ; 管 脚 2 接地 。( 英特尔 在 1976 年 发 布 了 8085 芯片 ， 目 的 
就 是 简化 对 这 些 电源 的 要 求 ) 


其 他 的 管 脚 都 标 有 箭头 。 从 忆 片 引出 的 箭头 表明 这 是 一 个 输出 〈output ) 信号 ， 这 种 
信和 号 由 微 处 理 器 控制 ， 计 算 机 的 其 他 芯片 对 该 信号 响应 。 指 向 芯片 的 箭头 表明 该 信号 是 
一 个 输入 (input ) 信号 ， 该 信号 由 其 他 芯片 发 出 ， 并 由 8080 芯片 对 其 响应 。 还 一 些 管 脚 
既是 输入 又 是 输出 。 


第 17 章 所 设计 的 处 理 器 需要 一 个 振荡 器 来 使 其 工作 。8080 需要 两 个 不 同 的 同步 时 钟 
输入 ， 它 们 的 频率 都 是 2 MHz， 分 别 标记 为 向 和 内 ， 位 于 管 脚 22 和 15 上 。 这 些 信 号 可 
以 很 方便 地 由 英特尔 生产 的 8224 时 钟 信号 发 生 器 产生 。 为 8224 连接 一 个 18 MHz 的 石英 
晶体 后 ， 它 基本 上 就 可 以 完成 其 余 工 作 了 。 


一 个 微 处 理 器 通常 有 多 个 用 来 寻 址 存储 器 的 输出 信号 。 用 于 寻 址 的 输出 信号 的 数目 
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+ 


与 微 处 理 器 的 可 寻 址 空间 大 小 直接 相关 。8080 有 16 个 用 于 寻 址 的 输出 信号 ,标记 为 Ao ~ 
Ais ， 因 此 它 的 可 寻 址 空间 大 小 为 26 ， 即 65,536 字 节 。 


8080 是 一 个 8 位 的 微 处 理 器 ， 可 以 一 次 从 存储 器 读 取 或 向 存储 器 写 入 8 位 数据 。 该 
芯片 还 包括 标记 为 Do ~ Dy 的 8 个 信号， 这 些 信号 是 芯片 仅 有 的 几 个 既 可 以 用 做 输入 又 
可 以 用 做 输出 的 信号 。 当 微 处 理 器 从 存储 器 中 读 取 一 个 字 节 时 ， 这 些 管 脚 的 功能 是 输入 ; 
当 微 处 理 器 向 存储 器 写 入 一 个 字 节 时 ， 其 功能 又 变 成 了 输出 。 


芯片 的 其 余 10 个 管 脚 是 控制 信号 ( control signals )。 例 如 ，RESET (复位 ) 输入 用 于 
控制 微 处 理 器 的 复位 。 输 出 信号 WR 的 功能 是 指明 微 处 理 器 需要 向 RAM 中 写 入 数据 
( WR 信号 对 应 于 RAM 阵列 的 写 输 入 )。 此 外 ， 当 芯片 读 取 指令 时 ， 在 某 些 时 刻 一 些 控制 
信号 会 出 现在 De ~ D; 管 脚 处 。 使 用 8080 芯片 构建 的 计算 机 系统 通常 使 用 8228 系统 控 
制 芯片 来 锁 存 附 加 的 控制 信号 。 本 章 在 后 面 将 会 讲述 一 些 控制 信号 。 但 8080 的 控制 信号 
是 极其 复杂 的 ， 因 此 ， 除 非 你 准备 用 该 芯片 搭建 一 台 计 算 机 ， 和 否则 最 好 不 要 在 这 些 控制 
信号 上 过 多 花费 时 间 。 


假设 8080 微 处 理 器 连接 了 一 个 64KB 的 存储 器 ， 这 样 我 们 就 能 独立 地 读 写 数据 而 不 
依赖 于 微 处 理 器 。 


8080 芯片 复位 后 ， 它 把 锁 存 在 存储 器 0000h 地 址 处 的 字 节 读 入 微 处 理 器 ， 通 过 在 地 
址 信号 端 A。~ An 输出 16 个 0 实现 该 过 程 。 它 读 取 的 字 节 必须 是 8080 指令 ， 读 取 该 字 
节 的 过 程 被 称 为 取 指令 〈instruction fetch )。 


在 第 17 章 设计 的 计算 机 中 ， 所 有 的 指令 (除了 HLT 指令 ) 都 是 3 个 字 节 长 ， 包 括 1 
字 节 的 操作 码 和 2 字 节 的 地 址 。 在 8080 中 ， 指 令 的 长 度 可 以 是 1 字 节 、2 字 节 , 或 者 3 
字 节 。 有 些 指令 使 8080 从 存储 器 的 一 个 特定 地 址 读 取 字 节 到 微 处 理 器 ,有些 指令 使 8080 
将 一 个 字 节 从 微 处 理 器 写 入 存储 器 的 特定 地 址 ; 还 有 些 指 令 使 8080 在 其 内 部 执行 而 不 需 
要 访问 RAM。8080 执行 完 第 一 条 指令 后 ， 接 着 从 存储 器 读 取 第 二 条 指令 ， 并 依 此 类 推 。 
这 些 指令 组 合 在 一 起 构成 了 计算 机 程序 ， 可 以 用 来 做 一 些 很 有 趣 的 事情 。 

当 8080 以 最 高 速度 2 MHz 运行 时 ， 每 个 时 钟 周 期 是 500ns (1 + 2,000,000 = 
0.000000500s )。 第 17 章 中 的 计算 机 的 所 有 指令 都 需要 4 个 时 钟 周期 , 8080 的 每 条 指令 需 
要 4~ 18 个 时 钟 周 期 ， 这 就 意味 着 每 条 指令 的 执行 时 间 为 2~9hs。 
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Ee 


也 许 了 解 某 个 特定 微 处 理 器 的 功能 的 最 好 办 法 就 是 全 面 地 测试 其 完整 的 指令 集 。 


第 17 章 最 后 完成 的 计算 机 仅 包括 12 条 指令 。 一 个 8 位 处 理 器 的 指令 数 很 容易 达到 
256， 每 一 条 指令 的 操作 码 就 是 一 个 特定 的 8 位 数 ( 如 果 某 些 指令 包含 2 字 节 的 操作 码 ， 
其 指令 集会 更 大 )。8080 虽然 没有 这 么 多 指令 ， 但 是 其 指令 数 也 已 经 达到 了 244。 这 看 起 
来 似乎 是 很 多 ， 但 从 总 体 上 说 ， 其 功能 并 不 比 第 17 章 的 计算 机 强大 。 例 如 ， 如 果 想 利用 
8080 进行 乘法 或 除法 运算 ， 你 仍然 需要 自己 写 一 小 段 代码 。 


在 第 17 章 曾经 讲 到 过 ， 为 了 方便 地 引用 指令 ,我 们 为 处 理 器 的 每 一 条 指令 的 操作 码 
都 指派 了 一 个 特殊 的 助 记 符 ,而且 其 中 的 一 些 助 记 符 是 可 以 带 有 参数 的 。 这 种 助 记 符 只 
是 在 我 们 使 用 操作 码 时 提供 方便 ， 它 对 于 处 理 器 是 没有 帮助 的 ， 处 理 器 只 能 读 取 字 节 ， 
对 于 助 记 符 组 成 的 文本 的 含义 一 无 所 知 ( 为 了 讲解 清楚 ， 本 书 选用 了 Intel 8080 说 明文 档 
中 用 到 的 部 分 助 记 符 为 例 来 说 明 )。 


第 17 章 设 计 的 计算 机 的 指令 集 包括 两 条 非常 重要 的 指令 ， 我 们 称 之 为 加 载 (Load ) 
和 保存 〈 Store )。 每 条 指令 占 3 个 字 节 。 在 Load 指令 中 ， 第 一 个 字 节 是 操作 码 ， 其 后 的 
两 个 字 节 是 要 加 载 的 操作 数 的 16 位 地 址 。 当 处 理 器 执行 加 载 指 令 时 ， 会 把 该 指定 地 址 中 
的 字 节 加 载 到 累加 器 。 与 之 相似 ， 当 Store 指令 被 执行 时 ， 累 加 器 中 的 内 容 被 保存 到 该 指 
令 指定 的 地 址 中 。 


我 们 可 以 用 助 记 符 把 上 述 代码 简写 为 以 下 形式 : 


LOD A, [aaaa] 
STO [aaaal, A 


这 里 的 A 表示 累加 器 〈 它 既是 Load 指令 的 目的 操作 数 也 是 Store 指令 的 源 操作 数 )， 
aaaa 表示 16 位 的 存储 器 地 址 ， 通 常用 4 个 16 进 制 的 数 来 表示 一 个 地 址 。 


同 第 17 章 的 累加 器 一 样 ，8080 的 8 位 累加 器 也 记 做 A。8080 也 有 与 第 17 章 的 计算 
机 的 Load 指令 和 Store 指令 功能 相同 的 两 条 指令 ,它们 也 称 做 加 载 ( Load ) 和 保存 ( Store )。 
在 8080 中 ， 加 载 指令 和 保存 指令 的 操作 码 分 别 是 32h 和 3Ah， 每 个 操作 后 面 也 同样 跟着 
一 个 16 位 的 地 址 。 在 8080 中 ， 它 们 的 助 记 符 分 别 是 STA ( Store Accumulator， 表 示 加 载 
到 累加 器 ) 和 LDA (Load Accumulator， 表 示 保 存 到 累加 器 ): 
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操作 码 指 令 
3 


3A LDA A, [aaaal 


8080 芯片 的 微 处 理 器 的 内 部 除 累 加 器 外 还 设置 了 6 个 寄存 器 (register ), 每 个 寄存 器 
可 以 存放 一 个 8 位 的 数 。 这 些 寄 存 器 和 累加 器 非常 相似 ， 事 实 上 累加 器 被 视 为 一 种 特殊 
的 寄存 器 。 这 6 个 寄存 器 和 累加 器 一 样 ， 本 质 上 都 是 锁 存 器 。 处 理 器 既 可 以 把 数据 从 存 
储 器 读 入 寄存 器 ， 也 可 以 把 数据 从 寄存 器 存 回 存储 器 。 当 然 ， 其 他 的 寄存 器 没有 累加 器 
所 具有 的 丰富 的 功能 ， 例 如 ， 当 把 两 个 8 位 数 相 加 时 ， 其 结果 总 是 保存 到 累加 器 而 不 会 
保存 到 其 他 寄存 器 。 


在 8080 中 用 B，C,，D,，E, 互 和 工 来 表示 新 增 的 6 个 寄存 器 。 人 们 通常 会 问 以 下 两 
个 问题 :“ 为 什么 不 使 用 F 和 G 来 表示 ? ”， 以 及 “I, J 和 KK 用 来 代表 什么 ? ”答案 是 ， 
使 用 和 工 来 命名 寄存 器 是 因为 它们 具有 特殊 的 含义 ，H 可 以 代表 高 (High ) 而 工 可 以 
代表 低 Low )。 通 常 把 两 个 8 位 的 寄存 器 H 和 和 工 合 起 来 构成 一 个 16 位 的 寄存 器 对 ( register 
pair )， 称 做 HL，H 用 来 保存 高 字 节 而 L 用 来 保存 低 字 节 。 这 个 16 位 的 值 通 常用 来 对 存 
储 器 寻 址 ， 我 们 将 在 下 面 看 到 它 是 怎样 以 简单 的 方式 工作 的 。 


寄存 器 是 计算 机 必 不 可 少 的 部 件 吗 ? 为 什么 在 第 17 章 搭建 的 计算 机 中 并 没有 寄存 器 
的 踪迹 ? 从 理论 上 讲 ， 这 些 寄存 器 不 是 必需 的 ， 在 第 17 章 也 没有 用 到 它们 ， 但 在 实际 应 
用 中 使 用 它们 将 带 来 很 大 的 方便 。 很 多 计算 机 程序 都 同时 用 到 多 个 数据 ， 将 这 些 数据 存 
放 在 寄存 器 比 存放 在 存储 器 更 便于 访问 ，. 因 为 程序 访问 内 存 的 次 数 越 少 其 执行 速度 就 越 
快 。 


在 8080 中 有 一 条 指令 至 少 用 到 了 63 个 操作 码 ， 这 条 指令 就 是 MOV， 即 Move 的 缩 
写 。 其 实 该 指令 是 一 条 单字 节 指 令 ， 它 主要 用 来 把 一 个 寄存 器 中 的 内 容 转移 到 另 一 个 寄 
存 器 (也 可 能 就 是 原来 的 寄存 器 )。 因 为 8080 微 处 理 器 设计 了 7 个 寄存 器 (包括 累加 器 
在 内 )， 因 此 应 用 中 使 用 大 量 的 MOV 指令 是 很 正常 的 。 


下 面 列 出 了 前 32 条 MOYV 指令 。 再 一 次 提醒 你 ， 两 个 参数 中 左 侧 的 是 目标 操作 数 ， 
右 侧 的 是 源 操作 数 。 
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这 些 指令 使 用 起 来 非常 方便 。 利 用 上 面 的 指令 可 以 方便 地 把 一 个 寄存 器 存放 的 数据 
转移 到 另 一 个 寄存 器 。 下 面 让 我 们 研究 一 下 以 HL 寄存 器 对 作为 操作 数 的 4 条 指令 。 


MOV B, [HLI] 


前 面 讲 过 LDA 指令 , 它 可 以 把 单字 节 的 操作 数 从 存储 器 转移 到 累加 器 ; LDA 操作 码 
后 面 直 接 跟 着 该 操作 数 的 16 位 地 址 。 在 上 面 列 出 的 指令 中 ，MOV 指令 把 字 节 从 存储 器 
转移 到 B 寄存 器 ， 但 该 字 节 的 16 位 地 址 却 存放 在 HL 寄存 器 对 中 。HL 是 怎样 得 到 16 位 
存储 器 地 址 的 呢 ? 这 并 不 难 解决 ， 有 很 多 方法 可 以 做 到 ， 比 如 通过 某 种 计算 实现 。- 


总 而 言 之 ， 对 于 下 面 这 两 条 指令 : 


LDA A, [aaaa] 
MOV B, [HL] 


它们 的 功能 都 是 把 一 个 字 节 从 内 存 读 入 微 处 理 器 ， 但 它们 寻 址 存储 器 的 方式 并 不 相同 。 
第 一 种 方式 称 做 直接 寻 址 〔 direct addressing ) ; 第 二 种 方式 称 做 间接 寻 址 (indexed 
addressing ) 。 


下 面 列 出 了 其 余 32 条 MOV 指令 , 我 们 看 到 HL 保存 的 16 位 存储 器 地 址 也 可 以 作为 
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i 


目标 操作 数 。 


ET ET 在 二 
人 5 | MoOv DB 


60 MOV 了 HB 70 MOV [HL],B 


61 MOV HC 71 MOV [HL],C 
62 MOV HLD 72 MOV [HL],D 


63 MOV HE 73 MOV [HL],E 


65 MOV H,L 
66 MOV H, [HL] 
67 MOV H,A 
68 MOV L,B 
69 MOV L,C 


6E 
6F MOV IL,A 


其 中 的 一 些 指令 如 : 
MOV A, A 
并 不 会 执行 有 意义 的 操作 。 而 指令 : 


MOV [HL], [HLI] 


是 不 存在 的 , 事实 上 ， 与 之 对 应 的 指令 是 HLT ( Halt ) 即 停止 指令 ， 也 就 是 说 该 指令 的 ; 
义 是 停止。 


涡 


研究 MOV 操作 码 的 位 模式 能 更 好 地 了 解 它 ，MOYV 操作 码 由 8 位 组 成 : 


O01ldddsss 


其 中 ddd 这 3 位 是 目标 操作 数 的 代码 ，sss 这 3 位 是 源 操作 数 的 代码 。 它 们 所 表示 的 意义 
如 下 : 
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000 = 寄存 器 B 
001 = 寄存 器 C 
010= 寄存 器 DD 
011= 寄存 器 E 
100= 寄存 器 HH 
101 = 寄存 器 L 
110= 寄存 器 HL 保存 的 存储 器 地 址 中 的 内 容 
111= 累加 器 A 


例如 ， 指 令 
MOV LIL, EE 


对 应 的 操作 码 为 : 


01101011 


十 六 进 制 数 可 表示 为 6Bh。 这 与 前 面 列 出 的 表格 是 一 致 的 。 


We 


可 以 设想 一 下 ,在 8080 的 内 部 可 能 是 这 样 的 : 标记 为 sss 的 3 位 用 于 8-1 数据 选择 
器 ， 标 记 为 ddd 的 3 位 用 来 控制 3-8 译 码 器 以 此 确定 哪 一 个 寄存 器 锁 存 了 值 。 


寄存 器 B 和 C 也 可 以 组 合成 16 位 的 寄存 器 对 BC， 同 样 我 们 还 可 以 用 D 和 了 组 成 寄 
存 器 对 DE。 如 果 这 些 寄存 器 对 也 包含 要 读 取 或 保存 的 字 节 的 存储 器 地 址 ， 则 可 以 用 下 面 
的 指令 实现 : 


2 


全 
仿 


STAX [BC],A LDAX A,[BC] 


STAX [DE],A LDAX A, [DBE] 


另 一 种 类 型 的 传送 (Move ) 指令 称 做 传送 立即 数 ( Move Immediate )， 它 的 助 记 符 写 
做 MVI。 传 送 立 即 数 指 令 是 一 个 双 字 节 指 令 ， 第 一 个 字 节 为 操作 码 ， 第 二 个 是 数据 。 这 
个 单字 节 数 据 从 存储 器 转移 到 某 个 寄存 器 ， 或 者 转移 到 存储 器 中 的 某 个 存储 单元 ， 该 存 
储 单元 由 HL 寄存 器 对 寻 址 。 
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ne 
| ”操作 码 指 令 
06 MVI B,xx 
OE MVI C,xx 
16 MVI D,xx 
1E MVI E,xx 
26 MVI H,xx 
2E MVI L,xx 
36 MVI [HL], xx 
3E MVI A,xx 
例如 ， 当 指令 : 
MVI E, 37h 
执行 后 , 寄存 器 B 存放 的 字 节 是 37h。 这 就 是 我 们 要 介绍 的 第 三 种 寻 址 方式 一 一 立即 数 寻 


址 (immediate addressing )。 


下 面 将 列 出 一 个 操作 码 集 ， 包 括 32 个 操作 码 ， 它 们 能 完成 4 种 基 ; 相 的 算术 运算 ， 这 
些 运算 在 第 17 章 设计 处 理 器 时 我 们 已 经 熟悉 了 , 它们 是 加 法 (ADD ) 进位 加 法 (ADC 入 


减法 (SUB ) 和 借 位 减法 (SBB )。 可 以 看 到 ， 在 所 


中 的 一 个 操作 数 ， 同 时 用 来 保存 计算 结果 。 这 些 指令 
操作 码 


的 例子 中 ， 累 加 器 


如 下 。 


人 如 


H<2N/ 


指 令 人 指 
ADD A,B SUB A,B 
91 SUB A,C 
92 SUB A,D 
93 SUB A,E 
94 SUB A,H 
ADD A,L 95 SUB A,L 
ADD A, [HIL] 96 SUB A, [HL] 
ADD A,A 97 SUB A,A 
ADC A,B 98 SBB A,B 
ADC A,C 
ADC A,D I SBB A,D 
ADC A,E SBB . A,E 
ADC A,H 
ADC A,L 
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I 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


| 


ADC A, [HI] | 9%E -| SBB A, [HL] 
9F 


ApC aA 


假如 累加 器 A 存放 的 字 节 是 


SUB A, B 


累加 器 中 的 值 变 为 22h， 


SBB A,A 


即 两 个 字 节 的 差 。 


35h， 累 加 器 B 存放 的 字 节 是 22h， 经 过 减法 运算 : 


如 果 累 加 器 A 中 的 值 为 3sh， 寄 存 器 互 和 L 中 的 值 分 别 是 10h 和 7Ch， 而 存储 器 地 
址 107Ch 处 的 字 节 为 4Ahb， 指 令 ; 


ADD A, [HL] 


并 把 计算 结果 (7Fh ) 保 


存 到 累加 器 。 


把 累加 器 中 的 值 (35h ) 与 寄存 器 对 HL 寻 址 (107Ch ) 存储 器 得 到 的 数值 (4Ah ) 相 加 ， 


在 8080 中 ， 使 用 ADC 指令 和 SBB 指令 可 以 对 16 位 数 、24 位 数 、32 位 数 甚至 更 高 


位 的 数 进 行 加 法 、 减 法 运算 。 例 如 ， 假 设 现在 寄存 器 对 BC 和 DE 各 自 保 存 了 一 个 16 位 


的 数 ， 我 们 要 把 这 两 个 数 相 加 ， 并 且 把 结果 保存 在 寄存 器 对 BC 中 。 有 具体 做 法 如 下 : 


MOV A, C 
ADD A, E 
MOV C, A 
MOV A, B 
ADC A, D 
MOV B, A 


; 低 字 节操 作 


; 高 字 节 操作 


在 上 面 的 计算 中 ， 用 ADD 指令 对 低 字 节 相 加 ， 用 ADC 指令 对 高 字 节 相 加 。 低 字 节 相 加 
产生 的 进位 会 进入 高 字 节 的 运算 中 。 在 这 段 简短 的 代码 中 ， 我 们 用 到 了 4 个 MOV 指令 ， 
利用 累加 器 进行 加 法 运算 ,操作 数 在 累加 器 和 寄存 器 之 间 来 回 地 


这 是 因为 在 8080 中 只 能 
传送 ， 因 此 在 8080 的 代 


码 中 会 大 量 使 用 MOV 指令 。 


现在 我 们 来 讨论 8080 的 标志 位 (flag )。 第 17 章 设计 的 处 理 器 已 经 有 了 CF 进位 标 
志 位 ) 和 ZF ( 零 标 志 位 ) 两 个 标志 位 ,在 8080 中 又 新 增 了 3 个 标志 位 ， 


SF, 奇偶 标志 位 PF 和 


助 进位 标志 位 AF。 在 8080 中 ， 用 一 个 专门 的 8 


包括 符号 标志 位 


位 寄存 器 来 存放 


所 有 标志 位 ， 该 寄存 器 称 做 程序 状态 字 ( Program Status Word，PSW )。 不 同 的 指令 对 标 
志 位 有 不 同 的 影响 ，LDA、STA 或 MOV 指令 始终 都 不 会 影响 标志 位 ， 而 ADD、SUB、 
ADC 以 及 SBB 指令 会 影响 标志 位 的 状态 ， 有 具体 情况 如 下 。 
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s 如 果 运 算 结果 的 最 高 位 是 1， 那 么 符号 标志 位 SF 标志 位 置 1， 表 示 该 计算 结果 是 


负数 。 


> 如 果 运 算 结果 为 0， 则 零 标志 位 ZF 置 0。 


s 如 果 运 算 结 果 中 “1 
PF 置 1; 反之 ， 如果 “1” 


”的 位 数 是 偶数 ， 即 具有 偶数 性 〈even parity )， 则 奇偶 标志 位 
的 位 数 是 奇数 ， 即 运算 结果 具有 奇数 性 (odd parity )， 


则 PF 置 0。 由 于 PF 的 这 个 特点 ， 有 了 时 会 被 用 来 进行 简单 的 错误 检查 。PF 在 8080 


程序 中 并 不 常用 。 


s 进位 标志 位 CF 的 情况 和 第 17 章 描 述 的 稍 有 不 同 , 当 ADD 和 ADC 运算 产生 进位 


或 者 SUB 和 SBB 运算 不 发 4 
4 辅助 进位 标志 位 AF 上 


FE 借 位 时 ，CF 都 置 1。 


结果 的 低 4 位 向 高 4 位 有 进位 时 才 置 1。 它 只 用 于 


DAA ( Decimal Adjust Accumulator, 十 进 制 调整 累加 器 ) 指令 中 。 


下 面 的 两 条 指令 会 


志 位 CF。 


= 
< 


第 17 章 设 计 的 计算 机 可 以 执行 ADD、ADC、SUB 和 SBB 指令 ( 虽然 缺乏 灵活 性 )， 
而 8080 功能 更 为 强大 ， 它 还 可 以 执行 AND (与 ) OR (或 )、 XOR ( 异 或 ) 等 逻辑 运算 。 


不 论 是 算术 运算 还 是 逻辑 运算 ， 都 是 由 8080 处 理 器 的 算术 逻辑 单元 ( ALU ) 来 完成 的 。 
以 下 是 8080 的 算术 运算 和 逻辑 运算 指令 。 


操作 码 


| 人 小 


BO0 
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AND、XOR 和 OR 都 是 按 位 运算 (bitwise operations ) 指令 ， 也 就 是 说 对 于 这 些 逻 辑 
运算 指令 ， 其 操作 数 的 每 一 个 对 应 位 都 是 独立 运算 的 ， 例 如 : 


MVI A, OFh 

MVI B, 55h 

AND A, B 
保存 到 累加 器 的 结果 将 会 是 05h。 假 如 我 们 把 3 条 指令 换 作 OR, 则 最 终 的 结果 将 会 是 5Fh; 
如 果 换 作 XOR， 则 结果 又 变 成 了 SAh。 


CMP〈Compare， 比 较 ) 指令 同 SUB 指令 类 似 ， 也 是 把 两 个 数 相 减 ， 不 同 之 处 在 于 
它 并 不 在 累加 器 中 保存 计算 结果 ， 计 算 的 目的 是 为 了 设置 标志 位 。 这 个 标志 位 的 值 可 以 
告诉 我 们 两 个 操作 数 之 间 的 大 小 关系 。 例 如 ， 我 们 考虑 下 面 的 指令 : 


MVI B, 25h 
CMP A, B 


由 令 执 行 后 , 累加 器 A 中 的 值 并 没有 变化 。 改 变 的 是 标志 位 的 值 , 如 果 A 中 的 值 等 于 25h， 
则 零 标志 位 ZF 置 1; 如 果 A 中 的 值 小 于 25h， 则 进位 标志 位 CF 置 1。 


同样 的 ， 也 可 以 对 立即 数 进行 这 8 种 算术 逻辑 操作 。 


例如 ， 可 以 用 下 面 的 这 条 指令 来 蔡 代 上 面 列 出 的 两 条 指令 : 


CPI A, 25h 


下 面 是 两 种 特别 的 8080 指令 。 
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CMA 是 Complement Accumulator 的 简写 。 它 对 累加 器 中 的 数 按 位 取 反 ， 即 把 0 变 为 
1，! 变 为 0。 例 如， 累加 器 中 的 数 如 果 是 01100101, 使 用 CMA 命令 后 ， 累 加 器 中 的 数 按 
位 取 反 ， 得 到 10011010。 我 们 还 可 以 使 用 如 下 指令 对 累加 器 中 的 数 取 反 : 


XRI A, FFh 


前 面 提 到 过 ，DAA 是 Decimal Adjust Accumulator 的 缩写 ， 即 十 进 制 调整 累加 器 ， 它 
可 能 是 8080 中 最 复杂 的 一 条 指令 。 在 8080 微 处 理 器 中 专门 设计 了 一 个 完整 的 小 部 件 用 
来 执行 该 指令 。 


DAA 指令 提供 了 一 种 用 二 进 制 码 表示 十 进 制 数 的 方法 ， 称 为 BCD 码 (binary-coded 
decimal ), 程序 员 可 以 在 该 指令 的 帮助 下 实现 十 进 制 数 的 算术 运算 。 BCD 码 采用 的 表示 方 
式 为 ， 每 4 位 为 一 段 ， 每 段 所 能 表示 数 的 范围 是 ，0000 ~ 1001， 对 应 十 进 制 数 的 0~ 9。 
因为 1 字 节 有 8 位 故 可 分 割 为 2 个 段 ， 因 此 在 BCD 码 格 式 下 ,一 个 字 节 可 以 表示 两 位 十 
进 制 数 。 

假设 累加 器 A 存放 的 是 BCD 码 表示 的 27h， 显然 它 就 对 应 十 进 制 数 的 27 (通常 , 十 
六 进 制 的 27h 对 应 的 十 进 制 数 是 39 )。 同 时 假设 寄存 器 B 中 存放 着 BCD 码 表 示 的 94h。 
假如 执行 如 下 指令 : 


MVI A, 27h 
MVI B, 94h 
ADD A, B 


累加 器 中 存放 的 最 终结 果 是 BBh， 当 然 ， 这 肯定 不 是 BCD 码 。 因 为 BCD 码 中 每 4 位 组 
成 的 段 所 能 表示 的 十 进 制 数 不 会 超过 9。 然 而 ， 当 我 们 执行 指令 : 

DAA 
那么 累加 器 最 后 所 保存 的 值 是 21h， 而 且 进 位 标志 位 CF 置 1。 因 为 十 进 制 的 27 与 94 相 
加 的 结果 为 121。 由 此 可 以 看 到 ， 使 用 BCD 码 进行 十 进 制 的 算术 运算 是 很 方便 的 。 


在 8080 程序 中 ， 经 常会 对 一 个 数 进行 加 1 或 减 1 运算 。 在 第 17 章 的 乘法 程序 中 ， 
为 了 实现 对 一 个 数 减 1， 我 们 把 该 数 与 FFh 相 加 ， 它 是 -1 的 补 码 。8080 提供 了 专门 的 指 
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INR 和 DCR 都 是 单字 节 指令 ， 它 们 可 以 影响 除 CF ( Carry Flag) 之 外 的 所 有 标志 位 。 


8080 还 包括 4 个 循环 移 位 ( Rotate ) 指令 ， 这 些 指 令 可 以 把 累加 器 中 的 内 容 向 左 或 向 


右 移动 1 位 ， 它 们 的 具体 功能 如 下 。 


Ee 
电 


义 
使 累加 器 循环 左 移 
使 累加 器 循环 右 移 


RAL “| 带 进 位 的 累加 器 循环 左 移 
RAR “| 带 进 位 的 累加 器 循环 右 移 


这 些 指令 只 对 进位 标志 位 CF 有 影响 。 


假设 累加 器 中 存放 的 数 是 A7h， 即 二 进 制 的 10100111。RLC 指令 使 其 每 一 位 都 向 左 
移 一 位 。 最 终 的 结果 是 ， 最 低位 〈 左 端 为 低位 ， 右 端 为 高 位 ) 移出 顶端 移 至 尾部 成 为 最 
高 位 ， 这 条 指令 也 会 影响 CF 的 状态 。 在 这 个 例子 中 CF 置 1， 最 后 的 结果 为 01001111。 
RRC 指令 以 同样 的 方式 进行 右 移 位 操作 。 如果 移 位 之 前 的 数 是 10100111, 执行 RRC 之 后 


将 变 为 11010011， 同 时 CF 置 1。 


较 之 RLC 和 RRC，RAL 和 RAR 指令 的 工作 方式 稍 有 不 同 。 执 行 RAL 指令 时 ， 累 


加 器 中 的 数 仍然 按 位 左 移 ,， 把 CF 中 原来 的 值 移 至 累加 器 


数值 的 最 后 一 位 ， 同 时 把 累加 


器 中 数据 的 原 最 高 位 移 至 CF。 例如 , 假设 累加 器 中 移 位 之 前 的 数 是 10100111 且 CF 为 0， 
执行 RAL 指令 后 , 累加 器 中 的 数 变 为 01001110 而 CF 变 为 1。 类似 的 ,如果 执 行 的 是 RAR 


站 令 ， 累 加 器 中 的 数 变 为 01010011 而 CF 变 为 1。 
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当 我 们 在 程序 中 需要 对 某 个 数 进行 匀 2 ( 左 移 ) 或 除 2 ( 右 移 ) 运算 时 ， 使 用 移 位 操 
作 会 使 运算 变 得 非常 简单 。 

我 们 通常 把 微 处 理 器 可 以 寻 址 访问 的 存储 器 称 为 随机 访问 存储 器 ( random access 
memory，RAM )， 主 要 的 原因 是 : 只 要 提供 了 存储 器 地 址 (有 多 种 方式 )， 微 处 理 器 可 以 
用 非常 简便 的 方式 访问 存储 器 的 任意 存储 单元 。RAM 就 像 一 本 书 ， 我 们 可 以 翻 到 它 的 任 
意 一 页 。 这 种 方式 很 方便 ， 它 不 像 存储 在 一 个 微缩 胶片 上 的 整个 星期 的 报纸 ， 为 了 阅读 
星期 六 的 内 容 ， 我 们 需要 扫描 几乎 整个 星期 的 内 容 。 同 样 ， 它 也 比 读 取 磁 带 快 得 多 ， 因 
为 当 我 们 要 听 最 后 一 首 歌 时 ， 需 要 快 进 磁带 的 一 整 面 。 微 缩 胶片 和 磁带 都 不 是 随机 访问 
的 ， 它 们 是 顺序 访问 〈sequential access ) 的 。 


显然 ， 随 机 访问 存储 器 是 非常 好 的 一 种 寻 址 方式 ， 对 于 经 常 访问 存储 器 的 微 处 理 器 
来 说 更 是 如 此 。 然 而 ， 在 某 些 情况 下 使 用 不 同 的 寻 址 方式 访问 存储 器 也 是 有 好 处 的 。 例 
如 ， 下 面 例子 中 的 这 种 存储 方式 既 不 是 随机 的 也 不 是 顺序 的 : 假设 你 在 办 公 室 工 作 ， 有 
人 会 到 你 办 公 桌 前 为 你 分 配 任 务 ， 每 一 项 工作 都 用 到 某 种 文件 来。 这些 工作 通常 有 这 样 
的 特点 ， 在 你 完成 某 项 工作 之 前 首先 要 做 男 一 项 相关 工作 ， 并 用 到 另 一 个 文件 夹 。 因 此 
你 只 能 放下 第 一 个 文件 夹 ， 并 在 它 上 面 打开 一 个 第 二 个 文件 夹 继续 工作 。 现 在 又 有 一 个 
人 给 你 分 配 了 一 个 比 前 一 项 优先 级 更 高 的 工作 ， 于 是 你 打开 第 三 个 文件 夹 放 在 前 面 两 个 
上 ， 继 续 工作 。 而 这 项 工作 也 需要 先 做 一 项 相关 工作 ， 于 是 你 只 好 再 打开 第 四 个 文件 来 ， 
现在 你 的 办 公 桌 上 已 经 堆 叔 了 站 个 文件 夹 了 。 


你 可 能 已 经 注意 到 了 ， 事 实 上 ， 这 些 堆 释 的 文件 夹 很 有 序 地 保存 了 你 干 活 的 顺序 轨 
迹 。 最 上 面 的 文件 夹 总 是 代表 优先 级 最 高 的 工作 ， 完 成 该 工作 之 后 就 可 以 做 接 下 来 的 工 
作 了 ， 依 此 类 推 。 最 后 当 你 处 理 完 办 公 梨 上 最 后 一 个 文件 夹 《 即 接受 的 第 一 个 任务 ) 后 ， 
就 可 以 回 家 了 。 


这 种 形式 的 存储 器 称 作 堆栈 (stack )。 使 用 堆栈 时 ， 我 们 以 从 底部 到 顶部 的 顺序 把 数 
据 存 入 堆栈 ,并 以 相反 的 顺序 把 数据 从 堆栈 中 取出 ， 因 此 该 技术 也 称 作 后 进 先 出 存储 器 
( last-in-first-out，LIFO )。 堆 栈 的 特点 是 ， 最 先 保存 到 堆栈 中 的 数据 最 后 被 取出 ， 而 最 后 
保存 的 数据 则 被 最 先 取 出 。 


同样 ， 在 计算 机 中 也 可 以 使 用 堆栈 ， 当 然 计 算 机 中 的 堆栈 保存 的 是 数据 而 不 是 工作 。 
大 量 的 实践 证 明 ， 在 计算 机 中 使 用 堆栈 技术 是 十 分 方便 的 。 通 常 把 将 数据 存 入 堆栈 的 过 
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本 后 的 语言 


程 称 作 压 入 


《push )， 把 从 堆栈 取出 数据 的 过 程 称 作 弹 出 《pop )。 


假设 你 正在 编写 一 个 汇编 语言 程序 ， 需 要 用 到 寄存 器 A、B、C 来 存储 数据 。 在 编写 
程序 的 过 程 中 , 你 注意 到 程序 需要 做 一 个 小 的 计算 , 并 且 该 计算 也 需要 用 到 寄存 器 A、B、 


C。 你 希望 在 完成 该 计算 之 后 仍然 回 到 原来 的 地 方 ， 并 且 仍 然 使 用 寄存 器 A、B、C 中 原 
先 存放 的 数据 。 


为 了 保存 寄存 器 A、B、C 原先 存放 的 数据 ， 可 以 简单 地 把 这 些 数据 保存 到 存储 器 中 
不 同 的 地 址 中 ， 需 要 进行 的 计算 完成 之 后 ， 再 把 这 些 数据 从 存储 器 转移 到 寄存 器 。 但 这 
种 方式 需要 记录 数据 存放 的 地 址 。 有 了 堆栈 的 概念 之 后 ， 我 们 可 以 用 一 种 更 清晰 的 方式 


来 处 理 这 个 问题 ， 即 把 这 些 寄存 器 中 的 数据 依次 存放 到 堆栈 中 。 


PUSH 
PUSH 
PUSH 


稍 后 将 


寄存 器 中 的 


A 

B 

C 
具体 解释 这 些 指令 实际 的 意义 。 现 在 需要 知道 的 是 ， 这 些 指令 以 某 种 方式 把 
内 容 保 存 到 先进 后 出 存储 器 。 这 些 指令 执行 之 后 ， 寄 存 器 中 原 有 的 数据 将 妥 


善 地 保存 下 来 ， 你 就 可 以 放心 地 使 用 这 些 寄存 器 进行 别 的 工作 了 。 为 了 取 回 原来 的 数据 ， 
可 以 使 用 POP 指令 把 它们 从 堆栈 中 弹出 ， 当 然 弹 出 的 顺序 和 原来 压 入 的 顺序 是 相反 的 。 
相应 的 POP 指令 如 下 所 示 。 


POP 
POP 
POP 


再 次 并 记 : 


C 
B 
A 


后 进 先 出 。 如 果 POP 指令 的 顺序 弄 错 了 ,将 会 引起 严重 的 错误 。 


我 们 可 以 在 程序 中 多 次 用 到 堆栈 而 不 会 引起 混乱 ,这 是 堆栈 机 制 的 一 个 特殊 优势 。 
例如 ， 在 我 们 要 编写 的 程序 中 已 经 把 寄存 器 A、B、C 中 的 数 保存 到 了 堆栈 ， 在 程序 的 另 
一 段 又 需要 把 寄存 器 C、D、E 中 的 数 保存 到 堆栈 ， 可 以 使 用 下 面 的 指令 


PUSH 
PUSH 
PUSH 


C 
D 


当然 ， 在 该 段 程序 中 还 需要 使 用 一 些 指令 将 保存 到 堆栈 中 的 数据 取 回 至 寄存 器 ， 这 


些 指令 是 : 
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POP EE 
POP D 
POP @ 


显然 ， 由 于 先进 后 出 的 原则 ， 这 些 数 据 在 先前 存放 的 C、B、A 中 的 数据 之 前 弹出 堆栈 。 


堆栈 的 功能 是 怎样 实现 的 呢 ? 首先 , 堆栈 其 实 就 是 一 段 普 通 的 RAM 存储 空间 , 只 是 
这 段 空间 相对 独立 不 男 作 他 用 。8080 微 处 理 器 设置 了 一 个 专门 的 16 位 寄存 器 对 这 段 存储 
空间 寻 址 ， 这 个 特殊 的 寄存 器 称 为 堆栈 指针 ( SP，Stack Pointer )。 


在 我 们 所 举 的 例子 中 , 对 于 8080 来 说 使 用 PUSH 和 POP 对 寄存 器 操作 实际 上 是 不 准 
确 的 。 在 8080 中 ， 执 行 PUSH 指令 实际 上 是 把 16 位 的 数据 保存 到 堆栈 ， 执 行 POP > 
是 把 这 些 数据 从 堆栈 中 取 回 至 寄存 器 。 因 此 ， 对 于 上 面 的 如 PUSH C，POP C 等 指令 ， 

们 对 其 进行 如 下 的 修改 。 


PUSH BC 指令 将 寄存 器 B 和 C 中 的 数据 保存 到 堆栈 ,而 POP ”BC 则 将 这 些 数据 

到 寄存 器 B 和 C 中 , 并 且 保 持原 来 的 顺序 。 最 后 一 行 指令 中 的 PSW 代表 程序 

大 态 字 ,如 前 所 述 , 这 是 一 个 8 位 的 寄存 器 ,用 于 保存 标志 位 。 最 后 一 行 的 PUSH 和 POP 

a PSW, 即 压 入 和 弹出 堆栈 的 数据 由 累加 器 和 PSW 中 的 

内 容 组 成 。 如 果 你 想 把 所 有 寄存 器 中 的 数据 及 全 部 标志 位 都 保存 到 堆栈 ， 可 以 使 用 下 面 
的 指令 


PUSH PSW 


PUSH BC 
PUSH DE 
PUSH HL 


堆栈 是 怎样 工作 的 呢 ? 我 们 假设 堆栈 指针 是 8000h， 当 执行 PUSH BC 指令 时 将 会 引 
发 以 下 操作 。 


s 堆栈 指针 减 1， 变 为 7FFFh。 
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于 


寄存 器 B 中 的 内 容 被 保存 到 堆栈 指针 指向 的 地 址 ， 即 存储 器 地 址 7FFFb 处 。 
# 推 栈 指针 减 1， 变 为 7FFEh。 
% 寄存 器 C 中 的 内 容 被 保存 到 堆栈 指针 指向 的 地 址 ， 即 存储 器 地 址 7FFEh 处 。 


类 似 的 ， 在 堆栈 指针 仍 为 7FFEh 的 情况 下 ,执行 POP BC 指令 时 会 将 上 面 的 步骤 反 


s 堆栈 指针 指向 的 地 址 (7FFEh ) 的 内 容 加 载 到 累加 器 C。 
sa 堆栈 指针 加 1， 变 为 7FFFh。 
» 堆栈 指针 指向 的 地 址 (7FFFh ) 的 内 容 加 载 到 累加 器 B。 
4 堆栈 指针 加 1， 变 为 8000h。 


每 执行 一 条 PUSH 指令 ， 堆 栈 都 会 增加 两 个 字 节 ， 这 可 能 会 导致 程序 出 现 一 些小 错 
误 一 一 堆栈 可 能 会 不 断 增 大 , 最 终 覆 盖 掉 存储 器 中 保存 的 程序 所 必需 的 代码 或 数据 。 这 种 
错误 被 称 作 堆栈 上 溢 (stack overflow )。 类似 的 ， 如 果 在 程序 中 过 多 地 使 用 了 POP 指令 ， 
则 会 过 早 地 取 完 堆栈 中 的 数据 从 而 导致 类 似 的 错误 ， 这 种 情况 称 为 堆栈 下 溢 〈 stack 
underflow )。 


如 果 8080 连接 的 是 一 个 64 KB 的 存储 器 ， 你 可 能 会 把 堆栈 指针 初始 化 为 0000h。 当 
执行 第 一 条 PUSH 指令 时 ， 堆 栈 指针 会 减 1 变 为 FFFFh， 即 存储 器 的 最 后 一 个 的 存储 单 
元 。 这 时 ， 堆 栈 的 初始 位 置 将 会 是 存储 器 的 最 高 地 址 ， 因 为 程序 的 代码 通常 从 0000h 开 

台 存 放 ， 因 此 两 者 将 保持 非常 远 的 距离 。 


8080 使 用 LXI 指令 为 堆栈 寄存 器 赋值 ，LXI 是 Load Extended Immediate 的 缩写 ， 即 
加 载 扩展 的 立即 数 。 下 面 的 这 些 指令 将 把 操作 码 后 的 两 个 字 节 保存 到 16 位 寄存 器 对 中 。 


操作 码 肯 人 
LXI BC, xxxx 
LXI DE, xxxx 


LXI HL, xxxx 


指令 : 


LXI BC, 527Ah 
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和 下 面 两 条 指令 等 价 : 


MVI B, 52h 
MVI C, 17Ah 


LXI 指令 保存 一 个 字 节 。 而 且 上 表 中 最 后 一 条 LXI 指令 为 堆栈 指针 赋 了 一 个 特殊 的 
值 。 通 常 下 面 的 指令 不 作为 微 处 理 器 复位 之 后 首先 执行 的 指令 之 一 。 


0000h: LXI SP, 0000h 


类 似 的 ， 还 可 以 对 寄存 器 对 和 堆栈 指针 进行 加 1 或 减 1 操作 ， 即 把 它们 看 做 16 位 寄 
存 器 。 


对 于 要 讨论 的 16 位 指令 , 我 们 可 以 再 看 一 些 例子 。 下 面 的 指令 把 由 任意 2 个 寄存 器 
组 成 的 16 位 寄存 器 对 的 内 容 加 到 寄存 器 对 HL 中 。 


这 些 指令 可 以 减少 操作 的 字 节 数 。 例 如 ， 上 面 的 第 一 条 指令 一 般 情 况 下 需要 6 个 字 


有 DC 
MOV 


~ 


MOV A, LI 
ADD A, C 
MOV L, A 
MOV A, H 
A; B 
H, A 


~ 


DAD 指令 一 般 用 来 计算 存储 器 地 址 ， 只 对 进位 标志 位 CF 有 影响 。 
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ee 吾 的 语言 


接 下 来 我 们 来 认识 一 下 各 种 各 样 的 指令 。 下 面 两 条 指令 的 特点 是 操作 码 后 面 都 跟着 2 
节 的 地 址 , 第 一 条 指令 把 二 寄存 器 对 的 内 容 保存 到 该 地 址 , 第 二 条 指令 把 该 地 址 的 内 
oe HL 寄存 器 对 。 
二 接 加 开 数 据 到 FU 


寄存 器 工 的 数据 保存 在 地 址 aaaa， 而 寄存 器 H 的 数据 保存 在 地 址 aaaa+1。 


下 面 的 两 条 指令 把 寄存 器 对 HL 保存 的 数据 加 载 到 程序 计数 器 和 堆栈 指针 。 
操作 码 


PCHT PC, Hi | 将 可 保存 的 数据 加 载 到 程序 计数 需 


SPHL SP HL 将 HL 保存 的 数据 加 载 到 堆栈 指针 


PCHL 指令 本 质 上 是 一 种 Jump 指令 , 它 把 HL 保存 的 存储 器 地 址 加 载 到 程序 计数 器 ， 
而 8080 处 理 器 要 执行 的 下 一 条 指令 就 是 程序 计数 器 所 指明 的 存储 器 地 址 中 存放 的 指令 。 
SPHL 指令 可 以 作为 另 一 种 为 堆栈 指针 赋值 的 指令 。 


下 面 的 两 条 指令 中 , 第 一 条 将 HL 保存 的 数据 与 堆栈 项 部 的 两 个 字 节 进行 交换 ; 第 二 
条 指令 将 HL 保存 的 数据 和 寄存 器 对 DE 保存 的 数据 进行 交换 。 


XTHL HL, [SP] | 把 HL 中 的 内 容 和 堆栈 顶部 2 个 字 节 进 行 交 换 
XCHG HL,DE | 把 DE 中 的 内 容 和 了 中 的 内 容 进行 交换 


除了 网 讲 过 的 PCHL 指令 外 ， 目 前 为 止 还 没有 介绍 过 8080 的 跳 转 指令 。 如 第 17 章 
所 述 , 在 处 理 器 中 专门 设置 了 一 个 称 为 程序 计数 器 PC 的 寄存 器 ， 它 用 来 保存 处 理 器 将 要 
取出 并 执行 的 指令 的 存储 地 址 。 通 常 ， 处 理 器 在 PC 的 指引 下 顺序 执行 存储 器 中 存放 的 指 
令 ， 但 有 一 些 指 令 ， 如 Jump ( 跳 转 )、Branch (分 支 ) 或 Goto ( 无条件 转 移 ) 一 一 使 处 理 
器 脱离 原来 的 执行 顺序 。 这 些 指令 使 PC 重新 加 载 男 外 的 值 , 处 理 器 要 执行 的 下 一 条 指令 
存放 于 存储 器 的 其 他 位 置 ， 而 不 在 按 原来 的 顺序 寻 址 。 


当然 ,原始 的 普通 跳 转 指 令 的 确 有 一 定 的 作用 ,但 从 第 17 章 得 来 的 经 验 可 以 知道 ， 
条 件 跳 转 (conditional jump ) 指令 的 作用 更 大 。 条 件 跳 转 指令 使 处 理 器 根据 某 些 标志 位 的 
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值 转移 到 特定 的 地 址 ， 这 些 标志 位 可 以 是 进位 标志 位 CF、 零 标志 位 ZF 等 。 正 是 由 于 条 
件 跳 转 指令 的 引入 ， 第 17 章 所 设计 的 自动 加 法 器 才 成 为 一 般 意 义 上 的 数字 计算 机 。 


8080 有 5 个 标志 位 ， 其 中 有 4 个 可 用 于 条 件 跳 转 指令 。8080 支持 9 种 不 同 的 跳 转 指 
令 , 包括 了 非 条 件 跳 转 指令 , 还 包含 根据 ZF( Zero Flag )、CF( Carry Flag )、PF( Parity Flag ) 
以 及 SF( Sign Flag ) 是 否 为 1 而 跳 转 的 条 件 跳 转 指令 。 


在 介绍 这 些 指令 之 前 ,首先 来 介绍 与 ump 指令 相关 的 另外 两 种 指令 。 第 一 种 是 Call 
(调用 ) 指令 ， 它 和 Jump 指令 类 似 ， 但 是 有 所 不 同 的 是 : 执行 Call 指令 后 ,程序 计数 器 
《Program Counter， 在 这 部 分 讲解 中 简称 PC ) 加 载 一 个 新 的 地 址 ,而 处 理 器 会 把 原来 的 地 
址 保存 起 来 ,保存 到 何 处 呢 ? 最 好 的 选择 自然 是 堆栈 了 。 


这 种 策略 使 Call 指令 有 效 地 记录 了 “从 何 处 跳 转 ”( where it jumped from )， 即 保存 了 
跳 转 之 前 的 相关 信息 。 堆 栈 中 保存 的 地 址 可 以 使 处 理 器 最 后 返回 到 转移 之 前 的 位 置 。 用 
于 返回 的 指令 称 为 Return( 返回 )。Retum 指令 从 堆栈 中 弹出 两 个 字 节 ， 并 把 它们 加 载 到 
PC 中 ， 这 样 就 完成 了 返回 到 跳 转 点 的 工作 。 


对 于 任何 处 理 器 来 说 ，Call 和 Return 指令 都 非常 重要 。 在 它们 的 帮助 下 ， 程 序 员 可 
以 在 程序 中 使 用 子 程序 ( subroutine ), 子 程序 是 一 段 频繁 使 用 的 完成 特定 功能 的 代码 (这 
里 的 “频繁 ”意味 着 “不 止 一 次 ”)。 对 于 汇编 语言 来 说 ， 子 程序 是 其 基本 的 组 成 部 分 。 


让 我 们 来 看 一 个 使 用 子 程序 的 例子 。 假 设 你 在 编写 一 个 汇编 语言 程序 ， 在 程序 的 某 
个 位 置 你 需要 把 两 个 字 节 相 乘 ， 因 此 你 编写 了 一 段 用 于 两 个 数 相 乘 的 代码 ， 然 后 继续 向 
下 写 ， 在 程序 的 男 一 个 位 置 你 发 现 需要 再 一 次 对 两 个 字 节 相 乘 。 因 为 你 已 经 写 过 把 两 个 
字 节 相 乘 的 代码 ， 所 以 只 需要 重复 使 用 这 些 代码 就 可 以 了 。 但 是 怎么 做 呢 ? 只 是 简单 地 
把 这 些 代码 重复 输入 到 存储 器 中? 我 们 希望 不 是 ， 因 为 这 样 做 不 仅 耽 误 时 间 而 且 浪 费 存 
储 空 间 ， 一 个 更 好 的 方法 是 跳 转 到 先前 写 的 那 段 乘法 代码 所 在 的 位 置 。 但 是 普通 的 Jump 
指令 不 能 完成 这 个 操作 ， 因 为 在 执行 乘法 之 后 不 能 准确 地 返回 程序 的 当前 位 置 。 因 此 你 
需要 使 用 Call 指令 和 Return 指令 来 帮助 你 实现 这 个 功能 。 


用 来 实现 两 个 数 相 乘 的 一 组 指令 可 以 作为 一 个 子 程序 。 下 面 我 们 将 看 到 这 个 子 程序 。 
在 第 17 章 的 乘法 程序 中 ， 被 乘 数 〈 还 有 乘积 ) 被 保存 在 存储 器 的 特定 位 置 ; 而 在 8080 
的 子 程序 中 , 乘 数 和 被 乘 数 分 别 存 放 在 寄存 器 B 和 寄存 器 C 中 , 乘积 保存 到 16 位 寄存 器 
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对 HL 中 。8080 中 的 乘法 子 程序 如 下 : 


Multiply: PUSH PSW ; 将 要 修改 的 寄存 器 的 原 内 容 保存 至 堆栈 
PUSH BC 
SUB H, H ; 将 HL《〈 即 乘积 ) 置 为 0000h 
SUB i 
MOV A, B ; 乘 数 送 至 累加 器 A 
CPI A, 00h ; 如果 累加 器 中 的 值 是 0， 则 结束 
JZ AllDone 
MVI B, O00h ; 将 BC 的 高 字 节 置 为 0 
MultLoop: DAD HL, BC ; 将 BC 的 内 容 加 到 HL 
DEC A ; 乘 数 减 1 
JNZ MultLoop ; 如 果 不 为 0， 则 跳 转 
AllDone: POP BC ; 将 堆栈 中 保存 的 数据 恢复 至 寄存 器 
POP PSW 
RET ; 返回 


注意 ， 上述 子 程序 的 第 一 行 有 一 个 标志 Multiply。 当 然 , 实际 上 这 个 标志 对 应 着 子 程 
序 在 存储 器 中 的 起 始 地 址 。 该 子 程序 在 开始 处 使 用 了 两 个 PUSH 指令 ， 这 是 因为 通常 在 
子 程序 的 起 始 处 要 保存 程序 用 到 的 寄存 器 。 


保存 寄存 器 后 ， 子 程序 下 面 要 做 的 是 把 寄存 器 也 和 L 置 0。 尽 管 可 以 使 用 MVI ( 转 
移 立 即 数 ) 指令 代替 SUB 指令 来 实现 该 操作 ， 但 这 样 会 用 到 4 个 字 节 而 不 是 2 个 字 节 的 
指令 。 子 程序 执行 成 功 后 ， 运 算 结果 会 保存 到 寄存 器 对 HL 中 。 


接 下 来 子 程序 把 寄存 器 B 中 的 数 ( 即 乘 数 ) 累加 器 A， 并 判断 该 数 是 否 为 0。 
如 果 为 0， 则 乘法 子 程序 结束 ， 因 为 乘 数 为 0。 寄存 器 H 和 工 已 经 为 0， 所 以 子 程序 
可 以 使 用 了 芭 (Jump IfZero ) 指令 POP 指令 。 


如 果 乘 数 不 是 0， 子 程序 会 把 寄存 器 B 置 为 0。 现在 寄存 器 对 BC 存放 的 是 16 位 的 
被 乘 数 ， 而 累加 器 中 存放 的 是 乘 数 。 接 下 来 DAD 指令 会 把 BC (被 乘 数 ) 加 到 HL (运算 
结果 ) 中 。A 中 的 乘 数 减 1， 如 果 结 果 不 为 0， 则 执行 JNZ ( 非 零 跳 转 ) 指令 ， 该 指令 会 
使 BC 再 次 加 到 HL。 这 个 循环 会 继续 执行 ， 直 到 循环 的 次 数 等 于 乘 数 为 止 〈 当然 也 可 以 
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利用 8080 的 移 位 指令 编写 一 个 更 有 效率 的 乘法 子 程序 )。 


在 程序 中 使 用 如 下 指令 来 调用 这 个 乘 沪 


MVI B, 25h 
MVI Cc, 12h 
CALL Multiply 


CALL 指令 把 PC 的 值 保 存 到 堆栈 中 , 被 保存 的 这 个 值 是 CALL 指令 的 下 一 条 指令 的 
地 址 ， 然 后 CALL 指令 将 使 程序 跳 转 到 标志 为 Multiply 的 指令 ， 即 子 程序 的 起 始 处 。 当 
子 程序 得 到 计算 结果 后 ， 执 行 RET ( 返回 ) 指令 ， 
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并 重新 设置 到 PC， 之 后 程序 将 继续 执行 CALL 指令 后 面 的 指令 。 


8080 指令 集 包括 条 件 CALL 指令 和 条 从 


站 令 小 得 多 。 下 面 的 表格 完整 地 列 出 了 这 些 指令 。 


两 种 典型 的 微 处 理 器 了 一 


子 程序 ， 例 如 ， 把 2Sh 和 12h 相 乘 : 


该 指令 使 保存 在 堆栈 的 PC 的 值 弹 出 ， 


F Return 指令 ， 但 它们 使 用 的 频率 比 条 件 跳 转 


条 件 。 | 操作 码 | 指令 | 操作 码 | 指令 |[ 操作 码 | ”指令 
None C9 RET C3 JMP aaaa CD 
Znot set C0 RNZ C2 JNZ aaaa C4 CNZ aaaa 
Z set C8 RZ CA JZ aaaa CC CZ aaaa 
C not set DO RNC D2 JNC aaaa D4 CNC aaaa 
C set D8 RC DA JC aaaa DC CC aaaa 
Odd parity EO0 RPO E2 JPO aaaa E4 CPO aaaa 
Even parity E8 RPE | 取 JPE aaaa EC CPE aaaa 
S not set FO RP F2 JPaaaa F4 CP aaaa 
S set Fe | RM FA JM aaaa FC CM aaaa 


正如 你 大 概 所 了 解 的 ， 存 储 器 并 不 是 连接 在 微 处 更 
算 机 系统 通常 需要 输入 /输出 设备 (IO ) 以 实现 人 机 交互 。 输 入 /给 


显示 器 等 。 


器 上 的 唯一 设备 。 一 个 完整 的 计 


设备 通常 包括 键盘 和 


微 处 理 器 是 如 何 与 外 围 设备 〈《peripheral， 除 存储 器 外 ， 与 微 处 理 器 连接 的 所 有 设备 
都 可 以 称 为 外 围 设备 ) 互相 通信 的 呢 ? 外 赎 设 备 配备 了 与 存储 器 类 似 的 接口 ， 微 处 理 器 


通过 与 某 种 外 围 设备 对 应 的 特定 地 址 ( 即 接口 ) 对 其 进行 读 写 操作 。 在 某 些 微 处 理 器 中 ， 


外 围 设备 实际 上 占用 了 一 些 通 常用 来 寻 址 存储 器 的 地 址 ， 这 种 结构 称 作 内 存 映 像 IO 
(memory-mapped IO )。 但 在 8080 中 , 除了 常规 的 65536 个 地 址 外 ,另外 增加 了 256 个 地 
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址 专门 用 来 访问 输入 /输出 设备 ， 它 们 被 称 作 IO 端口 (IO ports )。LO 地 址 信号 标记 为 
Ao ~A7y ,但 IO 的 访问 方式 与 存储 器 的 访问 方式 不 同 ,两 者 的 区 分 由 8228 系统 控制 蕊 
片 的 锁 存 信号 来 标识 。 


OUT( 输出 ) 指 令 把 累加 器 中 的 内 容 写 入 到 紧 跟 该 指令 后 的 字 节 所 寻 址 的 端口 ( port )。 


IN (输入 ) 指令 把 一 个 字 节 从 端口 读 入 到 累加 器 。 它 们 的 格式 如 下 所 示 。 


mr 


外 围 设备 有 时 候 需 要 获得 处 理 器 的 注意 。 例 如 ， 当 你 按 下 键盘 的 某 个 键 时 ， 处 理 器 
应 该 马上 注意 到 这 个 事件 。 这 个 过 程 由 一 个 称 为 中 断 (intermpt ) 的 机 制 实现 ， 这 是 一 个 
由 外 围 设备 产生 的 信号 ， 连 接 至 8080 的 INT 输入 端 。 


但 是 ， 当 8080 复位 后 ， 就 不 再 响应 中 断 。 程 序 必须 执行 EI ( Enable Interrupt ) 指令 
来 允许 中 断 ， 然 后 执行 DI ( Disable Interrupts ) 禁止 中 断 。 这 两 条 指令 如 下 所 示 。 


8080 的 INTE 输出 信号 用 来 指明 何 时 允许 中 断 。 当 外 围 设备 需要 中 断 微 处 理 器 的 当 
前 工作 时 ， 它 需要 把 8080 的 INT 输入 信号 置 为 1。8080 通过 从 存储 器 中 取出 指令 来 响应 
该 中 断 ， 同 时 控制 信号 指明 有 中 断 发 生 。 外 围 设备 通常 提供 下 列 指令 来 响应 8080 微 处 理 
器 。 


上 面 列 出 的 这 些 指 令 都 称 作 Restart〈 重 新 启动 ) 指令 ， 在 其 执行 的 过 程 中 也 会 把 当 
前 PC 中 的 数据 保存 到 堆栈 , 这 一 点 与 CALL 指令 类 似 。 但 Restart 指令 在 保存 PC 数据 之 
百 会 立刻 跳 转 到 特定 的 地 址 ， 而 且 是 根据 参数 的 不 同 将 跳 转 到 不 同 的 地 址 : 比如 RST 0 
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将 跳 转 到 地 址 0000h 处 ，RST 1 将 跳 转 到 地 址 00008h 处 ， 依 此 类 推 ， 最 后 的 RST 7 将 跳 
转 到 地 址 0038h 处 。 这 些 地 址 存放 的 代码 都 是 用 来 处 理 中 断 的 。 例 如 ， 由 键盘 引起 的 中 
断 将 执行 RST 4 指令 ， 程 序 将 跳 转 到 地 址 0020h 处 ， 该 地 址 存放 的 代码 将 负责 从 键盘 读 
入 数据 ( 完整 的 过 程 将 在 第 21 章 讲述 )。 


日 前 为 止 ， 我 们 已 经 介绍 了 243 个 操作 码 。 在 前 255 个 数 中 ， 有 12 个 没有 作为 操作 
码 使 用 ,它们 是 : 08h, 10h, 18h, 20h, 28h, 30h, 38h, CBh, D9h, DDh, EDh 和 FDh。 
下 面 还 需要 讲 到 一 个 操作 码 。 


操作 码 指令 
00 NOP 


NOP 代表 即 声明 ) no op no operation， 无 操作 )。NOP 指令 使 处 理 器 什么 操作 也 
不 执行 。 这 样 做 有 什么 好 处 呢 ? 填空 ， 即 保持 处 理 器 的 运行 状态 而 不 做 任何 事情 。8080 
可 以 热 行 一 批 NOP 指令 而 不 会 引起 任何 错误 事件 的 发 生 。 


本 章 不 准备 详细 介绍 Motorola 6800 微 处 理 器 , 因为 在 构造 和 功能 方面 它 与 8080 非常 


相似 。 下 面 是 6800 的 40 个 管 脚 的 功能 描述 图 。 
Vss— 1 40 | 时 一 RESET 
HALT —»*” 2 39 Iw— TSC 
全 一 辣子 38 上 一 
玉 G 一 ”| 4 37 OO— 
VMA s 36 a-— DBE 
NMI 6 35 
BA 7 34 R/W 
Yee 8 33 De 
Ag | 9 32 | 和 DT 
Ai®—| 10 31 | 二 站 7 
了 11 Ba 30 [>D; 
站 3 专 一 12 29 ma»D, 
A4 | 13 28 Ds 
六 5 所 一 于 27 he»Ds 
Ag | 13 26 MD 
次 > 16 25 FAs 
oa 17 24 Ai4 
Ay 18 23 Fr Ay 
起 提 二 49 22 FrAil 
All | 20 21 FF Vssg 


在 上 图 中 ，YVss 表示 接地 ，Vec 代表 5V 的 电源 。 同 8080 一 样 ，6800 也 有 16 个 地 址 
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输出 信号 端 和 8 个 数据 信号 端 ， 其 中 数据 信号 端 既 可 以 用 于 输入 信号 也 可 以 用 于 输出 信 
号 。 它 还 有 一 个 RESET 信号 端 和 一 个 R/W (read/write， 读 / 写 ) 信号 。 了 RQ 信号 代表 中 
断 请 求 。 与 8080 相 比 ，6800 的 时 钟 信号 较为 简单 ，6800 没有 设计 独立 的 IO 端口 ， 所 有 
的 输入 /输出 设备 的 地 址 都 是 存储 器 地 址 空间 的 一 部 分 。 


6800 有 一 个 16 位 的 程序 计数 器 PC、 一 个 16 位 的 堆栈 指针 SP、 一 个 8 位 的 状态 寄 
存 器 〈 用 来 保存 标志 位 )， 以 及 两 个 8 位 的 累加 器 A、B。A 和 B 都 可 以 用 做 累加 器 ( 而 
不 是 把 B 作为 普通 的 寄存 器 )， 因 为 A 和 B 的 功能 完全 相同 ,任何 用 A 做 的 工作 都 可 以 
用 了 B 实现 。 与 8080 不 同 ，6800 没有 设置 其 他 的 8 位 寄存 器 。 


6800 设置 了 一 个 16 位 的 索引 寄存 器 ( index register )， 它 可 以 用 来 保存 16 位 的 地 址 ， 
其 功能 与 8080 的 HL 寄存 器 对 相似 。 对 于 6800 的 大 部 分 指令 来 说 , 它们 的 地 址 都 可 以 由 
索引 寄存 器 与 紧 跟 在 操作 码 后 的 字 节 相 加 得 到 。 


加 法 、 减 法 、 移 位 、 跳 转 、 
调用 等 , 但 对 应 的 操作 码 和 助 记 符 是 完全 不 同 的 。 例 如 , 下 面 列 出 了 6800 的 转移 ( Branch ) 
间 令 集 。 


| 操作 码 | 指令 


A 转移 
大 于 则 转移 


等 或 小 于 则 转移 
进位 为 0 则 转移 
进位 为 1 则 转移 
不 相等 则 转移 
相等 则 转移 
溢出 置 0 则 转移 
溢出 置 1 则 转移 
a | 
Es 为 负数 则 转移 


大 于 或 等 于 0 则 转移 
小 于 0 tl 


es 0 则 转移 
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与 8080 不 同 ，6800 没有 设置 奇偶 标志 位 ， 而 是 设置 了 一 个 谥 出 标志 位 ( Overflow 
flag )。 上 面 的 转移 指令 中 有 一 些 依赖 于 标志 位 的 组 合 ( combinations of flags )。 


当然 ，8080 和 6800 的 指令 集 是 不 同 的 ， 虽然 这 两 款 芯 片 于 同一 年 发 布 , 但 它们 是 由 
属于 不 同 公司 的 两 组 不 同 的 工程 师 设计 的 。 这 就 造成 了 它们 之 间 的 不 兼容 ， 因 此 它们 不 
能 执行 对 方 的 机 器 码 ， 为 一 种 芯片 编写 的 汇编 语言 程序 也 不 能 在 男 一 种 芯片 上 执行 。 如 
何 编写 能 在 不 同类 型 处 理 器 上 执行 的 计算 机 程序 是 第 24 章 的 主题 。 


8080 和 6800 的 另 一 个 有 趣 的 区 别 是 : 在 两 个 处 理 器 中 ，LDA 指令 都 从 存储 器 的 特 
定 地 址 将 数据 加 载 到 累加 器 。 例 如 ， 在 8080 中 ， 下 面 的 字 节 序列 : 


8080 LDA 指令 


将 把 存储 器 地 址 347Bh 处 的 字 节 加 载 到 累加 器 。 现 在 对 比 一 下 6800 的 LDA 指令 , 它 使 
用 6800 扩展 寻 址 模式 (6800 extended addressing mode ): 


6800 LDA 指令 


上 面 的 这 组 字 节 序列 将 把 存储 器 7B34h 地 址 处 的 字 节 加 载 到 累加 器 。 


两 者 的 区 别 是 很 微妙 的 。 当 然 ， 你 可 能 已 经 注意 到 了 操作 码 的 不 同 : 8080 的 操作 码 
是 3Ah， 而 6800 的 操作 码 是 B6h。 但 是 两 种 微 处 理 器 对 紧 跟 在 操作 码 后 的 地 址 的 处 理 方 
式 是 不 同 的 , 8080 假设 低 字 节 在 前 , 高 字 节 在 后 ; 而 6800 假设 高 字 节 在 前 , 低 字 节 在 后 。 


Intel 和 Motorola 的 微 处 理 器 在 保存 多 字 节 数据 问题 上 的 根本 区 别 从 未 得 到 解决 。 直 
到 今天 ， 英特尔 的 微 处 理 器 在 保存 多 字 节 数据 时 ， 仍 然 把 最 低 有 效 字 节 放 在 最 前 面 (也 
就 是 说 ,在 最 低地 址 处 )， 而 Motorola 的 微 处 理 器 在 保存 多 字 节 数据 时 ,仍然 把 最 高 有 效 
字 节 放 在 最 前 面 。 


这 两 种 不 同 的 方式 分 别称 为 little-endian ( Intel 方式 ) 和 big-endian ( Motorola 方式 )。 
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| 
| 


争论 两 者 之 间 哪 一 种 方式 更 好 是 件 有 趣 的 事 , 但 在 这 么 做 之 前 , 先 要 知道 big-endian 这 个 
术语 出 自 乔纳森 * 斯 威夫 特 ( Jonathan Swift ) 的 Gulliver $ Tyavels, 指 的 是 刘 普 特 ( Lilliput ) 
和 布 鲁 夫 思科 ( Belfuscu ) 之 间 关 于 在 吃 鸡 重 之 前 应 该 辫 把 鸡蛋 的 哪 一 头 敲 碎 的 争论 。 因此， 
这 种 争论 可 能 是 没有 意义 的 ( 另 一 方面 ,坦白 地 说 ,在 本 书 第 17 章 设计 的 计算 机 所 采用 
的 方式 我 个 人 并 不 喜欢 )。 尽 管 不 能 确定 那 一 种 方式 本 质 上 是 “对 的 "， 这 种 差别 确实 造 
成 了 附加 的 兼容 性 问题 ， 这 种 问题 通常 会 在 采用 little-endian 和 big-endian 系统 的 机 器 共 
享 信息 时 出 现 。 


这 两 种 微 处 理 器 后 来 的 发 展 如 何 呢 ? 8080 被 应 用 在 一 些 人 所 谓 的 第 一 台 个 人 电脑 
( personal computer ) 上 ， 更 准确 地 说 应 该 是 用 于 第 一 台 家 用 电脑 (home computer ) 上 。 
下 图 是 Altair 8800， 它 曾 登 上 了 1975 年 1 月 的 Popular Electronics 杂志 的 封面 。 
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你 看 到 Altair 8800 时 ， 前 面板 上 的 灯泡 和 会 让 你 感到 似曾相识 。 这 个 界面 和 
第 16 章 介绍 64 KB RAM 阵列 时 的 初始 “控制 面板 ”的 界面 是 类 似 的 。 


在 8080 之 后 ，Intel 又 推出 了 8085 芯片 ， 而 具有 更 重大 意义 的 是 Z-80 芯片 的 出 现 。 
Z-80 是 由 Zilog 公司 制造 的 , 该 公司 是 英特尔 公司 的 竞争 对 手 , 由 英特尔 的 前 雇员 费 德 瑞 
克 ' 菲 戈 金 (Federico Faggin ) 创立 ， 费 德 瑞 克 “' 非 伐 金 曾 在 4004 芯片 的 研制 过 程 中 做 
出 重要 贡献 。Z-80 和 8080 完全 兼容 ， 并 且 增 加 了 许多 非常 有 用 的 指令 。1977 年 ，Z-80 
曾 被 应 用 在 Radio Shack TRS-80 Model 1 上 。 


同样 是 在 1977 年 ， 由 斯 蒂 夫 : 乔布斯 ( Steven Jobs ) 和 史蒂芬 ， 沃 兹 内 卡 ( Bei 
Wozniak ) 创立 的 苹果 计算 机 公司 推出 了 新 一 代 产 品 Apple I 。Apple I 既 没 有 使 用 8080 
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也 没有 使 用 6800, 而 是 使 用 了 基于 MOS 技术 的 更 加 便宜 的 6502 芯片 , 它 是 6800 的 改进 
加 强 版 本 。 


1978 年 6 月 ， 英 特 尔 公司 推出 了 8086 芯片 ， 这 是 一 个 16 位 的 微 处 理 器 ， 可 以 寻 址 
1MB 的 地 址 空间 。8086 的 操作 码 与 8080 不 兼容 ， 但 它 包 含 了 乘法 指令 和 除法 指令 。 一 
年 后 ， 英 特 尔 推出 了 8088 芯片 ， 其 内 部 结构 与 8086 完全 相同 ， 但 在 外 部 仍 以 字 节 为 单 
位 〈 即 外 部 接口 为 8 位 ) 访问 存储 器 ， 所 以 该 芯片 能 使 用 为 8080 设计 的 较为 流行 的 8 位 
的 外 围 芯片 《8-bit support chips )。IBM 在 5150 个 人 计算 机 中 使 用 了 8088 芯片 ， 这 种 计 
算 机 通常 称 为 IBM PC， 于 1981 年 秋季 推出 。 


IBM 大 举 进军 个 人 计算 机 (Personal Computer， 有 时 也 简称 为 PC ) 市 场 对 业界 产生 
了 重大 影响 ， 许 多 公司 都 推出 了 与 个 人 计算 机 兼容 的 机 器 (兼容 的 含义 将 在 随后 的 几 章 
里 详细 讨论 )。 多 年 以 来 ,，“IBM PC 兼容 ”也 瞳 示 了 “Intel inside”( 即 内 部 使 用 了 Intel 
微 处 理 器 )， 这 里 特 指 Intel x86 系列 微 处 理 器 。x86 系列 微 处 理 器 包括 1982 年 发 布 的 186 
芯片 和 286 芯片 ，1985 年 发 布 的 32 位 386 芯片 ，1989 年 发 布 的 486 芯片 。 从 1993 年 开 
台 ， 英 特 尔 公司 推出 Intel 奔腾 ( Intel Pentium ) 系列 微 处 理 器 ， 而 这 个 系列 如 今 被 广泛 地 
应 用 于 PC 兼容 机 。 虽 然 这 些 处 理 器 的 指令 集 都 在 不 断 扩展 , 但 是 它们 仍然 支持 始 于 8086 
的 所 有 早期 处 理 器 的 操作 码 。 


苹果 公司 的 Macintosh 于 1984 年 首次 发 布 , 它 采用 摩托 罗拉 的 68000 微 处 理 器 ,68000 
是 16 位 微 处 理 器 , 是 6800 的 下 一 代 产 品 。68000 及 其 后 续 产 品 ( 通常 称 为 68K 系列 ) 是 
已 发 布 的 处 理 器 中 最 受 欢 迎 的 一 类 。 


从 1994 年 开始 ，Macintosh 计算 机 开始 使 用 PowerPC 微 处 理 器 ， 该 处 理 器 是 由 摩托 
罗拉 ，IBM 以 及 苹果 公司 联合 开发 的 。PowerPC 是 采用 RISC (Reduced Instruction Set 
Computing， 精 简 指 令 集 计算 机 ) 微 处 理 器 体系 结构 来 设计 的 ， 其 目的 是 通过 某 些 方面 的 
简化 来 提高 处 理 器 的 速度 。 在 RISC 计算 机 中 ， 通 党 指令 都 是 等 长 的 (PowerPC 中 是 32 
位 ) 只 有 加 载 和 保存 两 种 指令 能 访问 存储 器 , 并 且 尽 量 简化 指令 的 操作 。RISC 处 理 器 设 
置 了 大 量 的 寄存 器 ， 这 样 就 能 避免 频 繁 访问 存储 器 以 提 其 高 运行 速度 。 

PowerPC 拥有 完全 不 同 的 指令 集 ， 因 此 不 能 执行 68K 系列 微 处 理 器 的 代码 。 然 而 ， 
目前 Macintosh 计算 机 使 用 的 PowerPC 微 处 理 器 可 以 仿真 (emulate ) 68K 系列 微 处 理 器 。 
运行 在 PowerPC 上 的 仿真 程序 逐一 检查 68K 程序 的 操作 码 ， 并 执行 相应 的 操作 。 它 执行 
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的 速度 没有 PowerPC 本 身 的 代码 那么 快 ， 但 可 以 正常 工作 。 


根据 摩尔 定律 (Moore’s Law )， 微 处 理 器 中 的 晶体 管 数量 每 18 个 月 翻 一 倍 ， 人 们 不 
禁 要 问 : 增加 的 这 些 大 量 的 晶体 管用 来 做 什么 呢 ? 


一 些 晶体 管用 来 适应 处 理 器 不 断 增 加 的 数据 宽度 一 一 从 4 位 、8 位 、16 位 到 32 位 ; 
男 一 些 新 增 的 晶体 管用 来 应 对 新 的 指令 。 例 如 ， 现 在 大 部 分 微 处 理 器 都 支持 用 于 浮 点 数 
的 指令 (将 在 第 23 章 详细 介绍 ); 还 有 一 些 新 增 的 指令 用 来 执行 重复 计算 ， 以 便 在 计算 
机 屏幕 上 呈现 图 片 和 电影 。 


现代 处 理 器 使 用 多 种 技术 来 提高 其 运行 速度 。 其 中 一 种 就 是 流水 线 技 术 ( pipelining )， 
即 处 理 器 在 执行 一 条 指令 的 同时 读 取 下 一 条 指令 , 尽管 Jump 指令 在 一 定 程 度 上 会 改变 这 
种 流程 。 现 代 处 理 器 还 包括 一 个 Cache ( 高 速 缓冲 存储 器 )， 它 是 一 个 设置 在 处 理 器 内 部 ， 
访问 速度 非常 快 的 RAM 阵列 ， 用 来 存放 处 理 器 最 近 要 执行 的 指令 。 由 于 计算 机 程序 经 常 
执行 一 些小 的 指令 循环 ,使 用 Cache 可 以 避免 反复 加 载 这 些 指令 。 上 面 提 到 的 这 些 提 高 
运行 速度 的 策略 都 需要 在 处 理 器 内 部 增加 更 多 的 逻辑 组 件 和 晶体 管 。 


正如 前 面 所 提 到 的 ， 微 处 理 器 只 是 整个 计算 机 系统 的 一 部 分 ( 尽管 是 最 重要 的 一 部 
分 )。 我 们 会 在 第 21 章 构造 这 样 一 个 系统 ， 但 首先 要 学 习 如 何 处 理 存储 器 中 的 数据 ， 包 
括 操 作 码 和 数字 ， 我 们 要 对 这 些 数 据 进行 编码 。 让 我 们 从 心态 上 回归 到 小 学 一 年 级 ， 像 
孩子 们 学 习 读 写 一 样 学 习 如 何 编码 吧 。 


入 . 306 


ASCII 公 和 
字符 转换 


数字 计算 机 中 的 存储 器 唯一 可 以 存储 的 是 比特 ， 因 此 如 果 要 想 在 计算 机 上 处 理 信息 ， 
就 必须 把 它们 按 位 存储 。 通 过 先前 的 学 习 ， 我 们 已 经 掌握 了 如 何 用 比特 来 表示 数字 和 机 
器 码 。 现 在 我 们 面临 的 一 大 挑战 就 是 如 何 用 它 来 存储 文本 。 毕 竟 ， 人 类 所 积累 的 大 部 分 
信息 ， 都 是 以 各 种 文本 形式 保存 的 。 文 本 信息 聚集 最 多 的 地 方 之 一 就 是 图 书馆 ， 数 不 清 
的 书 、 和 杂志 和 报纸 所 提供 的 都 是 文本 信息 。 当 然 ， 我 们 现在 已 经 使 用 计算 机 来 存放 图 像 
和 影音 信息 了 ， 不 过 为 了 易于 理解 ， 我 们 还 是 先 从 如 何 使 用 计算 机 存放 文本 开始 讲解 。 


为 了 将 文本 表示 为 数字 形式 ， 我 们 需要 构建 一 种 系统 来 为 每 一 个 字母 赋予 一 个 唯一 
的 编码 。 数 字 和 标点 符号 也 算 做 文本 的 一 种 形式 ， 所 以 它们 也 必须 拥有 自己 的 编码 。 简 
而 言 之 ， 所 有 由 符号 所 表示 的 字母 和 数字 ( Alphanumeric ) 都 需要 编码 。 具 有 这 种 功能 共 
系统 被 称 为 字符 编码 集 ( Coded Character Set )， 系 统 内 的 每 个 独立 编码 称 为 字符 编码 
( Character Codes )。 


许多 疑问 也 随 之 而 来 , 而 要 解决 的 第 一 个 问题 是 : 构成 这 些 编码 究竟 需要 多 少 比特 ? 


一 下 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 
[一 Se 


要 想 回 答 这 个 问题 就 需要 我 们 从 长 计 议 了 。 


当 考虑 用 比特 来 表示 文本 的 时 候 ， 切 鼠 好 高 玖 远 。 我 们 经 常会 看 到 书页 上 ， 或 报刊 
和 杂志 的 栏目 上 所 有 的 内 容 被 整齐 地 组 织 在 一 起 。 所 有 的 段落 都 划分 为 宽度 相等 的 文本 
行 ， 但 我 们 要 注意 ， 这 种 排版 的 形式 永远 只 是 文本 之 外 的 事物 。 当 曾 在 某 个 杂志 上 细 细 
上 品 味 过 的 一 个 故事 ， 几 年 后 与 我 们 在 另外 一 本 书 中 重 首 时， 我 们 回忆 起 的 往往 是 故事 本 
身 而 不 是 文本 的 排版 ， 没 有 人 会 因为 行 与 行 间距 的 不 同 而 把 它们 当成 两 个 故事 。 

我 极力 想 图 述 一 个 重要 的 观点 ， 那 就 是 文本 与 其 印刷 在 纸 上 时 采用 的 二 维 排版 格式 


是 两 码 事 。 充 分 发 挥 想象 力 ， 将 文本 看 成 是 一 维 的 由 字母 、 数 字 和 标点 符号 组 成 的 数据 
流 吧 。 当 然 ， 有 时 为 了 标明 一 名 话 的 开始 和 结尾 ， 还 需要 一 些 额 外 的 编码 。 


还 是 先前 所 描述 的 例子 ， 曾 在 某 个 杂志 上 细 细 品味 过 的 一 个 故事 ， 几 年 后 出 现在 另 
外 一 本 书 中 ,但 是 文章 的 字体 发 生 了 变化 ， 这 算是 一 个 问题 吗 ? 当年 的 杂志 上 是 这 样 印 
刷 的 : 


Call me lshmael. 
而 现在 书 中 的 写法 变 成 了 下 面 这 样 : 
Call me Ishmael. 


这 些 区 别 是 我 们 所 在 意 的 吗 ? 答案 往往 是 否定 的 。 字 体 改 变 了 文本 的 表现 形式 ， 但 故事 
本 身 的 内 容 并 没有 因此 而 改变 。 字 体 是 可 以 变 来 变 去 的 。 但 这 并 无 大 碍 。 | 


还 有 一 种 简化 问题 的 方法 : 我 们 可 以 总 是 使 用 毫 无 修饰 的 文本 。 没 有 斜体 、 粗 体 、 
下 画 线 、 颜 色 、 空 心 体 、 上 标 、 下 标 以 及 音标 ， 同 样 的 ， 这 里 没有 元 音字 母 标识 等 符号 ， 
只 有 赤 条 条 的 拉丁 字母 ， 这 些 字 母 组 成 了 英语 中 99% 的 文本 。 


在 先前 对 莫 尔 斯 码 和 布 莱 叶 言 文 的 学 习 中 ,我 们 了 解 了 如 何 将 字母 表 中 的 字符 以 二 
进 制 的 形式 表现 出 来 。 这 些 系统 在 适合 的 场合 很 好 用 ， 但 要 想 用 到 计算 机 中 却 是 难 上 加 
难 。 就 拿 莫 尔 斯 码 来 说 ， 它 是 变量 自 适 应 长 度 (Variable-Width ) 编码 : 常用 字符 的 编码 
较 短 ， 而 不 常用 字符 的 编码 较 长 。 这 样 的 编码 非常 适合 电报 系统 ， 但 并 不 适用 于 计算 机 。 
另外 ， 莫 尔 斯 码 并 不 区 分 字母 的 大 小 写 。 


布 莱 叶 盲文 编码 使 用 固定 宽度 ， 非 常 适合 计算 机 使 用 。 每 一 个 字符 对 应 着 6 比特 的 
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编码 , 并且 用 到 了 转 义 (Escape ) 码 对 大 小 写 进行 了 区 分 。 转 义 码 用 来 表明 下 一 个 字符 为 
大 写 。 这 也 就 是 说 ， 每 个 大 写字 母 都 需要 两 组 编码 来 表示 。 布 莱 叶 言 文中 用 移 位 〈Shif ) 
码 表示 数字 : 移 位 码 后 紧 跟 的 编码 都 被 看 做 数字 ， 直 到 遇 到 下 一 个 移 位 码 ， 此 时 系统 又 
将 后 面 的 内 容 当 做 字母 。 


我 们 的 目标 是 开发 一 个 字符 编码 集 ， 使 用 这 个 编码 集 ， 系 统 可 以 将 如 下 的 句子 转换 
成 为 一 系列 的 编码 : 


了 Payve 27 sisters. 


每 一 个 字符 的 编码 都 会 占据 一 定 的 比特 。 有 的 编码 用 来 表示 字母 ， 有 的 用 来 表示 标点 符 
号 ， 还 有 一 些 用 来 表示 数字 。 甚 至 于 单词 间 的 空格 也 需要 单独 的 编码 。 上 面 的 句子 中 共 
18 个 字符 (包括 字 间 空格 ) 对 这 样 一 个 句子 进行 编码 后 得 到 的 连续 字符 通常 被 称 为 文本 
字符 串 ( string )。 


我 们 需要 对 字符 串 中 的 数字 进行 编码 ， 例 如 上 面 的 句子 中 的 27。 或 许 大 家 会 感到 疑 
惑 ， 因 为 之 前 我 们 都 是 用 比特 来 表示 数字 的 。 最 简单 的 ， 也 是 最 容易 想到 的 做 法 就 是 使 
用 二 进 制 数 10 和 111 作为 2 和 7 的 编码 。 但 是 这 里 却 不 适用 。 在 这 个 句子 中 ， 可 以 像 处 
理 其 他 的 字符 一 样 来 处 理 2 和 7。 它们 的 编码 可 以 和 本 身 表示 的 含义 无 关 。 


1874 年 由 法 国电 报 服务 公司 (French Telegraph Service) 职员 埃 米尔 : 波多 ( Emile 
Baudot ) 发 明了 可 以 打印 的 电报 机 ， 划 时 代 的 波多 电 传 码 也 应 运 而 生 。 即 使 在 今天 来 看 ， 
这 种 编码 十 分 “经 济 划 算 ”， 每 一 个 文本 字符 都 采用 5 位 编码 。 这 种 编码 1877 年 被 法 国 
电报 服务 公司 采纳 ， 后 来 经 唐纳德 默 里 ( Donald Murray ) 修改 ， 最 终 在 1931 年 被 当年 
的 CCITT 组 织 ( Comité Consultatif International Télégraphique et Téléphonique )， 即 现在 的 
国际 电信 联盟 (ITU ) 定 为 标准 。 该 编码 的 正式 名 称 是 国际 电报 字母 表 第 二 号 ( Intemational 
Telegraph Alphabet No.2) 或 ITA - 2， 在 美国 常常 被 称 为 波多 印字 电报 制 (Baudot )， 不 过 
更 准确 地 说 ， 叫 做 默 里 《Murray ) 编码 。 


随 着 20 世纪 的 到 来 ，Baudot 被 广泛 应 用 于 电 传 打字 机 (teletypewriters)。Baudot 电 
传 打 字 机 配备 了 一 个 输入 键盘 ， 这 款 键盘 有 些 像 打 字 机 ， 但 只 有 30 个 键 和 一 个 空格 键 。 
电 传 打字 机 键盘 上 的 每 一 个 键 实质 上 都 起 到 了 转换 器 的 作用 ， 它 负责 产生 二 进 制 编码 并 
且 通 过 输出 电缆 逐 位 传输 出 去 。 电 传 打 字 机 也 具备 打印 功能 ， 通 过 输入 电缆 读 取 编 码 ， 
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| 


触发 电磁 铁 ， 从 而 将 字符 打印 在 纸 上 。 


由 于 Baudot 对 每 个 字符 采用 5 位 编码 , 整个 系统 由 32 个 编码 所 组 成 , 这 些 编码 的 十 
六 进 制 取 值 范围 从 00h 到 1Fh。 下 表 给 出 了 32 个 不 同 编码 的 十 六 进 制 形式 及 其 所 对 应 的 
字母 表 中 的 字符 。 


一 


12 
16 
17 
18 


| 
| 
和 


19 


| 
三 三 | 
0B G TB 
Be Sl 
0E C 


C 


编码 00h 被 保留 了 下 来 ， 没 有 指派 给 任何 值 。 剩 下 的 31 个 编码 中 ， 字 母 表 中 的 字符 
占 了 26 个, 其余 5 个 用 来 调整 格式 ， 如 上 表 中 的 楷体 排版 的 语句 所 示 。 


编码 04h 用 来 表示 空格 ， 通 常用 于 分 隔 单词 。 编 码 02h 和 08h 表示 的 是 回 车 和 换行 。 
这 些 都 是 电 传 打 字 机 中 的 专用 术语 。 当 使 用 电 传 打字 机 上 打字 ， 一 旦 到 了 一 行 的 末尾 时 ， 
我 们 通常 会 按 下 一 个 操作 杆 或 按钮 。 这 个 操作 其 实 包括 两 个 动作 : 第 一 个 动作 是 ， 使 打 
印 机 的 福 架 回 到 起 始 位 置 ， 这 样 打印 下 一 行 时 可 以 从 纸 的 最 左边 开始 ， 这 就 是 回 车 。 第 
二 个 动作 是 ， 将 打印 机 的 祖 架 移 至 正在 使 用 中 的 位 置 的 下 一 行 ， 这 就 是 换行 。 在 Baudot 
编码 系统 中 ， 这 两 个 编码 由 专门 的 按键 产生 。Baudot 电 传 打字 机 在 打印 的 时 候 会 响应 这 
两 个 编码 以 完成 相应 的 操作 。 


Baudot 系统 里 怎么 没有 数字 和 标点 符号 昵 ? 其 实 这 是 因为 编码 1Bh 中 暗藏 女 机 ， 它 
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的 实际 作用 是 数字 转 义 (Figure Shift )。 数 字 转 义 编码 后 的 所 有 的 编码 都 会 被 解释 为 数字 
或 标点 符号 ， 直 到 遇 到 字符 转 义 编码 ( 1Fh )， 一 切 就 又 被 解释 为 字符 。 下 表 展 示 了 十 六 
进 制 编码 以 及 所 对 应 的 数字 和 标点 符号 。 


下头 过 和 现 二 天 表册 二 
| 


其 实在 ITU 规范 化 的 编码 方案 中 ，05h、0Bh 和 16h 是 留 做 他 用 的 ， 官 方 说 法 为 “国内 使 
用 ”。 表 中 列 出 的 是 这 几 个 编码 在 美国 使 用 时 的 含义 。 某 些 欧洲 国家 将 这 些 编码 代表 重音 
符号 。 响 铃 编 码 令 电 传 打字 机 发 出 清脆 的 铃声 。“Who Are You” 编 码 用 来 让 打字 员 激 活 身 
份 识别 机 制 。 

像 莫 尔 斯 码 -一 样 ， 这 种 5 位 的 编码 并 没有 提供 区 分 大 、 小 写 的 方法 。 下 面 这 个 句子 : 

TSPENT825TODAY 
表示 成 编码 的 十 六 进 制 数据 流 就 是 : 
0C 04 140D 10.06 04 04 18 16 19 01 1F 04 01 03 12 18 15 18 07 02 08 

请 注意 三 个 转 义 码 的 使 用 : 1Bh 出 现在 数字 之 前 ，1Fh 出 现在 数字 之 后 ， 而 数字 结束 之 后 
又 出 现 了 1Bh。 这 一 行 编码 以 回 车 、 换 行 符 结尾 。 


问题 出 来 了 ， 如 果 把 相同 的 数据 流 再 一 次 输入 到 电 传 打印 机 ， 人 情况 就 大 不 一 样 了 ， 
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编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


于 


如 下 所 示 : 
I SPENNT $25 TODAY. 
8'03,5 $25 TODAY. 
怎么 会 这 样 ? 这 是 由 于 在 接收 到 第 二 行 编码 之 前 打印 机 接收 到 的 最 后 一 个 转 义 码 是 数字 
转 义 码 ， 所 以 当 直 见 第 二 行 开 头 儿 个 编码 时 ， 打 印 机 将 它们 解释 成 数字 。 


这 种 问题 产生 的 根源 就 是 采用 了 转 义 码 ， 这 的 确 很 让 人 头痛 。 尽 管 Baudot 电 传 码 是 
很 简洁 实用 的 编码 ， 但 是 ， 我 们 更 加 希望 采用 能 唯一 表示 字符 、 数 字 及 标点 符号 的 编码 
方案 ， 如 果 还 能 对 大 、 小 写 进 行 区 分 那 就 更 好 不 过 了 。 


如 果 想 知道 比 Baudot 更 好 用 的 编码 系统 中 一 个 编码 需要 多 少 比特 ,我 们 需要 做 儿 个 
小 加 法 : 所 有 的 大 小 写字 母 加 起 来 共 需 52 个 编码 ，0 ~9 数字 需要 10 个 编码 ， 加 起 来 共 
有 62 个 ， 如 果 算 上 一 些 标点 符号 ， 数 量 超过 了 64 个 ， 也 就 是 说 ， 一 个 编码 至 少 需要 6 
比特 。 但 无 论 如 何 字符 数 应 该 不 超过 128 个 ， 而 且 应 该 远 远 不 够 128 个 ， 也 就 是 说 编码 
长 度 不 会 超过 8 位 。 


所 以 ,答案 就 是 7。 在 采用 7 位 编码 时 ， 不 需要 转 义 字符 ， 而 且 可 以 区 分 字母 的 大 小 
写 。 


这 些 字符 编码 是 什么 样子 的 呢 ? 其 实 我 们 可 以 随意 编码 。 如 果 我 们 要 去 打造 一 台 自 
己 的 计算 机 ， 计 算 机 硬件 的 每 一 个 部 分 都 要 亲自 制作 ， 计 算 机 内 部 的 程序 也 要 亲手 编号 ， 
而 且 不 打算 把 这 台 计 算 机 与 其 他 的 进行 连接 ， 那 么 就 完全 可 以 构造 自己 的 编码 系统 。 其 
实 也 很 简单 ， 就 是 给 每 一 个 字符 指派 一 个 唯一 的 编码 。 

但 是 这 种 自己 制造 计算 机 ， 并 且 独 立 使 用 的 情况 实在 是 太 少 了 ， 所 以 所 有 人 都 遵循 
并 使 用 统一 化 的 编码 ， 计 算 机 的 存在 才 有 意义 。 这 样 一 来 ， 使 用 不 同方 法 制造 出 的 计算 
机 之 闻 就 可 以 互相 兼容 ， 甚 至 可 以 互相 交流 文本 信息 。 


这 样 一 来 ， 随 意 的 编码 就 显得 不 太 合适 了 。 当 我 们 使 用 计算 机 来 处 理 文本 时 ， 如 果 
字母 表 中 字母 的 编码 是 按 顺 序 来 的 ， 就 会 给 我 们 的 工作 带 来 很 多 便利 ， 显 而 易 见 的 优点 
就 是 ， 字 母 的 排序 和 分 类 将 变 得 简单 易 行 。 


季 运 的 是 ， 这 种 标准 已 经 存在 并 且 被 广泛 使 用 ， 它 被 称 为 美国 信息 交换 标准 码 
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(American Standard Code for Information Interchange )， 简 称 为 ASCIH 码 ， 发 音 很 像 
ASS-key。 从 1967 年 正式 公布 至 今 ， 它 一 直 是 计算 机 产业 中 最 重要 的 标准 。 不 过 还 有 一 
个 大 的 例外 (后 面 会 讲 到 )， 无 论 何 时 ， 当 你 在 计算 机 上 处 理 文本 时 ， 总 会 在 不 经 意 间 使 
用 到 ASCII 码 。 


ASCII 码 是 7 位 编码 , 它 的 二 进 制 取 值 范围 为 0000000 ~ 1111111, 对 应 于 十 六 进 制 就 
是 00h ~ 7Fh。 现 在 我 们 一 起 来 讨论 下 ASCII 码 ， 但 我 不 建议 从 开始 学 起 ， 因 为 相对 于 后 
面 的 编码 ， 前 32 个 编码 理解 起 来 还 有 一 点 难度 。 所 以 我 们 从 第 2 组 32 个 编码 开始 学 习 ， 
它 包括 标点 符号 和 10 个 数字 。 下 表 列 出 了 这 32 个 字符 及 相应 的 十 六 进 制 编码 。 


值得 注意 的 是 20h 代表 空格 符 ， 它 的 作用 是 将 单词 或 句子 隔 开 。 


接 下 来 的 32 个 编码 是 大 写字 母 和 一 些 附加 的 标点 符号 的 编码 。 除 了 @ 符 号 和 下 画 线 
之 外 ， 其 余 的 符号 很 难 在 打字 机 上 找到 。 它 们 真正 出 现 的 地 方 是 标准 计算 机 键盘 ， 下 表 
列 出 了 这 些 字符 及 相应 的 十 六 进 制 编码 。 


十 六 进 制 编码 | ”ASCI 字符 ”『 ”十 六 进 制 编码 ASCI 字符 
0 | e@e | 50 
41 51 
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一 T 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
. 


再 接 下 来 的 32 个 编码 是 所 有 小 写字 母 和 一 些 附加 的 标点 符号 及 其 对 应 的 十 六 进 制 纺 
码 ， 这 些 字符 也 很 少 在 打字 机 上 出 现 。 


ET TE 
Pe l 
| 
| 
NN 

= 
> 
EE rr hr no 
Ee 
ee a 
一 > 2 
1 EE i 
| 元 
人 ) 
EE EE 
一 人 


注意 ， 表 的 最 后 不 包括 7Fh 及 其 对 应 的 字符 。 如 果 你 统计 一 下 ， 就 会 发 现 这 三 张 表 
共 涵 盖 了 95 个 字符 。 由 于 ASCII 码 的 编码 长 度 为 7 位 ， 所 以 最 多 可 以 表示 128 个 编码 ， 
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四 | 


这 样 算 下 来 还 剩 33 个 编码 可 用 。 下 面 我 们 通过 儿 个 简短 的 例子 学 习 一 下 编码 。 
像 这 样 一 段 字 符 囊 : 
Hello, you! 
转换 成 ASCII 码 ， 用 十 六 进 制 数 表示 如 下 : 
48 65 6C 6F 2C 20 79 6F 75 21 


这 段 编码 中 ， 除 了 普通 的 字符 ， 逐 号 (编码 2C )、 空 格 ( 编码 20 ) 和 感 路 号 (编码 21 ) 
容易 遗漏 ,需要 额外 注意 。 我 们 再 来 看 一 个 例子 : 


T am 12 years old. 
它 用 ASCII 码 表示 为 : 
49 20 61 6D 20 31 32 20 79 65 61 72 73 20 6F 6C 64 2E 


有 意思 的 是 数字 12 的 表示 方法 。 在 这 上段 编码 串 中 ， 它 被 表示 成 十 六 进 制 数 31h 和 32h， 
也 就 是 数字 1 和 2 的 ASCII 码 的 组 合 。 当 数字 12 以 文本 流 的 身份 出 现时 ， 不 应 该 用 十 六 
进 制 码 01h 和 02h， 或 者 BCD 码 12h， 或 者 0Ch 来 表示 。 因 为 这 些 编码 在 ASCII 码 中 表 
示 其 他 的 意思 。 


在 ASCII 码 中 ,一 个 大 写字 母 与 其 对 应 的 小 写字 母 的 ASCI 码 值 相差 20h。 这 种 规律 
大 大 简化 了 程序 代码 的 编写 ,例如 一 段 将 特定 的 字符 串 变 成 大 写 的 程序 。 假 设 有 一 个 字符 
串 存 放 在 内 存 的 某 个 区 域 ， 每 个 字符 占据 一 个 字 节 。 下 面 是 一 段 8080 子 程序 ， 初 始 状态 下 
字符 串 的 首 地 址 存放 在 寄存 器 HL 中 ; 寄存 器 C 存放 字符 串 的 长 度 ， 也 就 是 字符 的 个 数 。 


Capitalize: MOV A, C ; c 表示 剩余 的 字符 数 
CPI A, O00h ”与 0 进行 比较 
JZ AllDone ”如果 琵 余 的 字符 数 为 0， 程 序 结束 
MOV A, [HLI ; 取得 下 一 个 字符 
CPI A, 61h ; 判断 A 代表 的 字符 的 ASCII 码 是 否 比 "a’ 小 
JC Skipit ; 如 果 比 "a’ 小， 就 跳 过 
CPI A, 78h ; 判断 是 否 比 'z' 大 
JNC SkipIt ; 如 果 是 ， 则 跳 过 
SBI A, 20h ; 判断 是 否 是 小 写 ， 如 果 是 ， 则 减 20n 
MOV [HL], A ; 保存 修改 过 的 字符 
SkipIt: INX HL ; 指向 下 一 个 字符 
DCR C ; 计数 器 减 一 
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i 
t 
i 


JMP Capitalize ; 返回 到 程序 起 始 处 
AllDone: RET 


还 有 另外 一 种 方法 也 可 以 将 小 写字 母 减 去 20h 而 转换 成 大 写字 母 ， 如 下 所 示 : 


ANI A, DF 


ANI 指令 (AND Immediate ) 用 来 “与 ”一 个 立即 数 。 在 上 面 这 个 例子 中 ， 累 加 器 中 
的 数值 与 DFh 执行 “ 按 位 与 ”操作 ,其 中 DFh 转换 成 二 进 制 数 就 是 11011111。“ 按 位 与 ” 
操作 就 是 把 两 个 数 分 别 转 换 成 二 进 制 ， 然 后 将 对 应 的 位 进行 “与 ”操作 。 这 个 例子 中 ， 
除了 自 左 向 右 数 的 第 3 位 被 置 成 0 外 ，A 中 的 其 他 位 均 被 保留 。 通 过 将 这 一 位 设置 为 0， 
我 们 实现 了 将 小 写字 母 的 ASCII 码 转换 成 大 写字 母 的 目的 。 
十 六 进 制 编码 缩写 | 控制 字符 的 全 义 | 
NUL 空 字符 
标题 开始 
文本 开始 
文本 结束 


水 平 制 表 
换行 
垂直 制 表 


换 页 
移出 
移入 
转 义 

设备 控制 1 


I 
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了 


续 表 

天 传输 结束 

媒介 取消 
SUB 蔡 代 字符 
ESC 跳出 
FS | 文件 分 割 或 信息 分 割 4 ] 
GS 组 分 制 或 信息 分 割 3 
RS | 记录 分 钊 或 信息 分 着 2 
US 单元 分 割 或 信息 分 割 1 
DEL 删除 

前 面 讲 到 的 95 个 编码 也 被 称 为 图 形 文字 (graphic characters )， 因 为 它们 可 以 被 显示 


出 来 。 其 实 ASCII 码 还 包含 33 个 控制 字符 ( control characters )， 它 们 用 来 执行 某 一 特定 
功能 ， 因 而 不 用 显示 出 来 。 为 了 完整 地 讨论 ASCII 编码 ， 下 面 将 这 33 个 控制 字符 也 列举 
出 来 ， 有 一 些 的 确 很 难 理 解 ， 不 过 不 用 在 意 。 其 实在 ASCII 码 公 布 以 后 ， 当 时 人 们 更 多 
的 是 想 把 它 用 在 电 传 打字 机 上 ， 所 以 ， 如 今 其 中 的 许多 编码 已 经 渐渐 离开 了 人 们 的 视线 。 


人 们 最 初 的 想法 是 可 以 在 图 形 字符 中 使 用 控制 字符 ， 以 便 对 文本 格式 进行 基本 的 调 
整 。 举 个 例子 或 许 会 帮助 你 更 好 地 理解 这 种 做 法 : 假如 有 一 台电 传 打字 机 或 者 打印 机 ， 
它 负 责 解析 ASCII 码 ， 解析 之 后 做 出 相应 的 操作 ,最 后 在 纸 上 打 印 出 字符 。 设 备 的 打印 
头 每 打印 一 个 字符 就 向 右 移动 一 格 ， 通 过 这 种 方式 来 对 ASCII 码 做 出 响应 。 而 要 实现 这 
些 操作 就 需要 用 到 控制 字符 。 


举 个 例子 来 讲 ， 看 看 下 面 这 个 十 六 进 制 字符 囊 : 


4109 42 098 43 09 
编码 09 代表 水 平 制 表 符 ， 简 写 为 Tab。 假 设 打 印 的 过 程 中 ， 所 有 水 平 排列 字符 的 起 
台 位 置 都 为 0，Tab 的 作用 是 在 下 一 个 水 平 位 置 即 在 距 前 一 个 字符 的 间距 为 字符 长 度 8 倍 
的 位 置 打印 下 一 个 字符 ， 如 下 所 示 : 


A B C 
这 种 简单 有 效 方法 使 得 字符 可 以 保持 按 列 对 齐 。 
有 一 些 控制 字符 甚至 沿用 至 今 , 例如 换 页 符 ( 12h )， 它 使 得 打印 机 跳出 当前 页 ， 并 
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一 一 广 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 


台 准 备 打 印 下 一 页 o 


回 退 符 可 以 用 来 打印 复合 字符 ， 尤 其 是 在 一 些 旧 的 打印 机 上 。 假设 计算 机 要 控制 电 
传 打字 机 ， 使 其 不 仅 打印 小 写字 母 e， 还 要 将 其 重音 标记 出 来 ， 即 8&。 我们 可 以 使 用 回 退 
符 来 实现 ， 十 六 进 制 码 为 : 65 08 60。 


计算 机 中 的 回 车 和 换行 与 Baudot 码 中 表示 的 意思 相同 ， 它 们 可 以 算得 上 是 控制 符 中 
最 重要 的 两 个 符号 。 在 打印 机 中 ， 回 车 符 使 得 打印 头 换行 并 转移 至 当前 页 面 的 最 左 端 ， 
换行 符 使 打印 头 转移 至 当前 位 置 下 一 行 。 这 两 种 操作 都 使 得 打印 头 移 至 新 的 一 行 。 回 车 
符 通常 用 来 另 起 一 行 继续 打印 ， 换 行 符 通 常 在 不 需要 移 到 页 面 最 左 端 而 换行 时 使 用 。 


尽管 ASCII 码 在 计算 机 领域 可 以 说 是 一 统 江湖 ， 但 许多 IBM 大 型 机 上 却 没有 采用 这 
种 标准 。 例 如 ，System /360 产品 内 部 采用 的 是 IBM 自发 研制 的 8 位 字符 编码 系统 ， 也 被 
称 为 扩展 的 BCD 交换 码 (Extended BCD Interchange Code )， 或 EBCDIC (英文 中 的 发 音 
为 EBB-see-dick ), EBCDIC 是 早期 的 6 位 BCDIC 编码 的 扩展 形式 , BCDIC 的 起 源 于 IBM 
的 打 孔 卡 。 一 张 打 孔 卡 一 一 存储 容量 为 80 个 文本 字符 一 一 1928 年 由 IBM 首创 并 沿用 了 将 
近 50 年 ， 它 的 外 观 如 下 图 所 示 。 


ABCDE FOHI SKLMNOPORST UYNXYZ 
ESS 


GE234565729 


800000600609000093 0 000600 00 
re en 
2222222 国 22222222 图 222222222222222222 国 22222222222222222222222222222222222222222 
33 量 33333333 国 33333333 罩 333333333333333333 国 3333333333533333333333333333333333333333 
引 和 和 4 3344 本 4 人 4 攻略 生生 玫 生生 二 届 作 生生 本 训 和 和 矣 本 二 和 是 二 民 于 生生 二 汪 生 避 明寺 生 在 二 汪 贞 再 关 古 不 寺 则 放 二 训 记 村 二 于 二 这 各 
55555555 和 548553506565555555555550555 有 S55 55555 55 
556655655555 S66655 56065055066 5566666605665656 66066060 065686566 565566566656 
727777B 277727778 277772277 57777777773727773 ?7 ?77 7777977ITIFI7IY??II777 I? I RIITIY 


EBLERY EEGEMLE EEREEL BECEEDEELEEL LLL EBD LET EL 


人 


在 考虑 打 孔 卡 与 8 位 EBCDIC 字符 码 的 关系 时 ， 需 要 知道 ， 在 几 代 技术 的 影响 下 ， 这 种 
编码 也 历经 几 十 年 的 演变 。 因 此, 打 孔 卡 与 EBCDIC 之 间 的 逻辑 性 和 一 致 性 也 逐渐 消失 了 。 


打 孔 卡 上 每 一 列 穿 出 的 一 个 或 多 个 矩形 孔 代表 一 个 字符 ， 而 这 些 字符 一 般 也 打印 在 
卡片 的 项 部 。 最 下 面 的 10 行 由 数字 标识 ， 让 全 全 让 0 行 、 第 1 行 直 到 第 9 行 。 
第 0 行 上 面 的 一 行 通常 不 出 现 数字 ， 称 为 第 11 行 ， 顶 端 为 第 12 行 ， 这 里 没有 第 10 行 。 


以 下 面 列举 一 些 IBM 打 孔 卡 的 常用 术语 : 第 0~ 9 行 称 做 数字 行 ( digit rows ) 或 数字 
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穿孔 ( digit punches ), 第 11 和 12 行 被 称 做 区 域 行 ( zone rows ) 或 区 域 穿孔 ( zone punches )。 
由 于 不 统一 ，IBM 打 孔 卡 用 起 来 有 时 会 有 些 混乱 : 比如 有 的 卡片 把 第 0 和 第 9 行 看 做 是 
区 域 行 而 不 是 数字 行 。 


一 个 EBCDIC 字符 码 由 8 位 比特 组 成 , 进一步 可 以 细 分 为 高 半 字 节 (4 比特 ) 与 低 半 
字 节 。 低 半 字 节 是 BCD 码 ， 与 字符 的 数字 穿孔 保持 一 致 ， 高 半 字 节 与 区 域 穿 孔 的 编码 保 
持 一 致 (而且 与 区 域 穿 孔 一 一 对 应 )。 回 忆 一 下 第 19 章 的 BCD 编码 原理 ， 其 本 质 是 采用 
二 进 制 数 对 十 进 制 数 进行 编码 (binary-coded decimal ) 一 一 其 中 数字 0~ 9 都 利用 不 同 的 4 
位 二 进 制 数 进行 编码 。 


数字 0~ 9 并 不 需要 区 域 穿孔 进行 额外 表示 ,它们 的 EBCDIC 编码 的 高 半 字 节 是 1111 ， 
代表 了 区 域 穿 孔 不 起 作用 , 而 0~9 的 EBCDIC 编码 的 低 半 字 节 是 数字 穿孔 的 BCD 码 ， 
如 下 所 示 。 


TA 


大 写字 母 有 一 些 有 趣 的 规律 ， 如 果 区 域 穿孔 只 出 现在 第 12 行 ， 则 高 半 字 节 标 识 为 
1100; 如 果 只 出 现在 第 11 行 ， 则 高 半 字 节 标 识 为 1101; 如 果 出 现在 第 0 行 ， 则 高 半 字 节 
标识 1110。 下 表 给 出 了 大 写字 母 及 其 对 应 的 EBCDIC 编码 。 


下 编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 


值得 注意 的 是 R 与 S 之 间 编 号 有 跳 变 。 有 时 在 编写 程序 的 时 候 ， 尤 其 是 程序 中 用 到 
EBCDIC 编码 时 ， 这 个 容易 被 忽视 的 小 细节 往往 会 令 人 抓 狂 。 


小 写 与 大 写字 母 的 数字 穿孔 是 相同 的 , 但 它们 的 区 域 穿孔 不 同 。 在 a~i 的 小 写字 母 ， 
穿孔 位 于 第 12 行 和 第 0 行 ， 高 半 字 节 对 应 的 编码 为 1000; 在 j~r 的 小 写字 母 ， 穿 孔 位 于 
第 12 行 和 第 11 行 ， 高 半 字 节 对 应 的 编码 为 1001; 在 s~z 的 小 写字 母 ， 穿 孔 位 于 第 11 行 
和 第 0 行 ， 高 半 字 节 对 应 的 编码 为 1010。 小 写字 母 的 EBCDIC 字符 及 其 对 应 的 十 六 进 制 编 
码 如 下 表 所 示 。 


十 六 进 制 编码 |EBCDIC 字符 | 


十 六 进 制 编码 


人 EECDIC 字符 


当然 ， 标 点 符号 和 控制 字符 也 都 有 自己 的 EBCDIC 编码 ， 但 对 于 这 些 字 符 的 编码 系统 没 

仔细 观察 IBM 打 孔 卡 , 其 中 每 一 列 细 细 数 下 共有 12 个 孔 , 每 个 孔 代 表 1 位 , 也 就 是 
说 可 以 提供 12 位 的 编码 信息 ， 不 是 吗 ? 我 们 其 实 可 以 用 打 孔 卡 上 每 一 列 12 孔 中 的 7 个 
来 表示 ASCII 码 。 但 是 ， 这 种 方案 有 一 个 非 技术 方面 的 缺陷 ， 那 就 是 太 多 的 穿孔 将 使 得 
卡片 变 得 很 脆弱 ， 容 易 折断 。 


采用 8 位 编码 的 EBCDIC 中 其 实 还 有 很 多 编码 未 定义 ， 这 也 说 明 当 年 ASCII 码 采 用 
了 7 位 编码 也 是 合乎 情理 的 。 在 ASCII 码 刚刚 问世 的 那个 年 代 ， 存 储 器 的 价格 贵 得 令 人 
咋舌 ， 有 一 些 观 点 认为 ASCII 码 可 以 用 6 位 编码 并 配合 转 义 字符 来 使 用 ， 这 样 既 可 以 区 
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20 ASCII 码 和 字符 转换 i 


分 大 小 写 又 节约 了 存储 器 。 这 种 方案 并 没有 被 采纳 ， 当 时 还 有 一 些 人 认为 ASCII 码 应 采 
用 8 位 编码 ， 他 们 对 计算 机 的 体系 结构 有 了 一 个 大 胆 的 推测 ， 即 计算 机 应 该 按 字 节 存储 ， 
7 位 存储 是 不 合适 的 。 今 天 来 看 ，8 位 的 字 节 存储 已 经 作为 了 一 项 标准 。 尽 管 ASCI 码 从 
技术 的 本 质 上 来 看 是 7 位 编码 ， 但 仍 以 8 位 的 形式 存储 。 


在 字 节 与 字符 之 间 建 立 一 种 等 价 关 系 大 大 简化 了 我 们 的 工作 ， 举 例 来 讲 ， 如 果 要 粗 
略 估计 一 个 文本 文件 所 需要 的 存储 空间 ， 只 要 统计 字符 数 就 可 以 了 。 这 时 前 面 学 过 的 及 
( kilos ) 和 M (Megas ) 就 派 上 了 用 场 ， 用 它们 来 表示 文本 所 占据 的 计算 机 存储 空间 更 加 
通俗 易 懂 。 


传统 的 排版 格式 是 : 一 张大 小 为 8.5x11 英寸 的 打印 纸 ， 采 用 双 倍 行距 ，1 英寸 的 页 
边 距 ， 每 页 可 以 容纳 约 27 行 的 正文 。 每 行 宽度 约 为 6.5 英寸 ， 每 英寸 可 容纳 10 个 字符 ， 
通过 计算 可 以 知道 每 页 共 包含 约 1750 个 字 节 。 如 果 页 面 采 用 单 倍 行距 ， 那 么 打印 纸 的 容 
量 约 为 原先 的 2 倍 ， 即 3.5 KB。 


翻 开 一 本 《纽约 窜 》( The New Yorker ) 杂志 ， 可 以 看 到 杂志 每 页 有 3 栏 ， 每 栏 包含 
60 行 ， 每 行 约 有 40 个 字符 ， 这 样 算 下 来 每 页 大 致 包 含 7200 个 字符 (也 可 以 说 成 字 节 )。 


《纽约 时 报 》( New York Times ) 每 一 页 包含 6 栏 。 假 如 页 面 都 是 文字 而 不 包含 标题 和 图 片 
(这 其 实 是 不 大 可 能 的 ), 那么 可 以 认为 每 栏 包含 155 行 , 每 行 大 约 容纳 35 个 字符 , 这 样 算 下 来 
整个 页 面 共 包含 32,550 个 字符 ， 即 32 KB。 


一 般 来 讲 精装 书 每 页 大 约 包含 500 个 单词 。 根据 统计 , 每 个 单词 平均 占用 5 个 字母 一 
一 更 确切 地 来 讲 应 该 是 6 个 字母 ， 因 为 单词 与 单词 之 间 是 通过 空格 来 分 隔 的 ， 所 以 要 一 
并 统计 在 内 。 这 样 算 下 来 , 书 的 每 一 页 大 约 包 含 3000 个 字符 。 假 设 每 本 书 平均 页 数 为 333， 
这 个 估计 或 许 和 实际 不 符 ， 但 如 果 这 样 估算 的 话 ， 每 本 书 平均 容量 为 1 MB。 


不 得 不 承认 的 是 ， 书 与 书 之 间 干 差 万 别 ， 所 以 上 面 这 些 也 只 是 估算 ， 下 面 列举 出 一 


斯 科 特 ' 菲 奖 杰 拉 德 (F. Scott Fitzgerald ) 的 《了 不 起 的 盖 茨 比 》( The Great Gatsby ) 
大 约 300KB。 


塞 林 格 (J.D. Salinger ) 的 《麦田 守望 者 》( Catcher in the Rye ) 大 约 400 KB。 


马克 寺 温 (Mark Twain ) 的 《 哈 克 贝 里 . 弗 恩 历险 记 和 The Adventures of Huckleberry 
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一 二 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
Te 0 


1 


Finn ) 大 约 540 KB。 


约翰 斯 坦 贝克 ( John Steinbeck ) 的 《愤怒 的 葡萄 / 怒火 之 花 》( The Grapes of Wrath ) 
大 约 1MB。 


) 椰 


" 梅 尔 维尔 ( Herman Melville ) 的 《 白 鲸 》( Moby Dick) 大 约 1.3 MB。 


享 利 非 尔 丁 (Henry Fielding ) 的 《 弃 儿 汤姆 :琼斯 的 历史 了》 The History of Tom Jones ) 
大 约 2.25 MB。 


玛 格 丽 特 . 米 切 尔 (Margaret Mitchell ) 的 《乱世 佳人 》( Gone With the Wind) 大 约 
2.5 MB。 


斯 蒂 芬 * 金 ( Stephen King ) 的 《末日 青 近 》( The Stand ) 大 约 2.7 MB。 


列 夫 ， 托 尔 斯 泰 (Leo Tolstoy ) 的 《战争 与 和 平 》( War anq Peace ) 大 约 3.9 MB。 


马 塞 尔 ' 普 鲁 斯 特 (Marcel Proust ) 的 《追忆 似 水 年 华 》( Remembrance of Things Post ) 
大 约 7.7 MB。 


美国 国会 图 书馆 ( The United States Library of Congress) 藏书 约 为 2000 万 本 , 大 概 有 
20 万 亿 字 符 ， 从 存储 器 角度 来 说 ， 数 据 总 量 为 20 TB (这 还 不 包括 图 书馆 中 的 大 量 珍贵 
照片 和 录音 资料 )。 


尽管 ASCII 码 是 计算 机 领域 最 重要 的 标准 ， 但 它 并 不 是 十 全 十 美的 。 它 的 问题 就 草 
含 在 它 的 全 称 中 American Standard Code for Information Interchange, 它 是 太美 国 化 了 1! 
即使 那些 以 英语 为 主要 语言 的 国家 ，ASCII 码 也 并 不 适用 。ASCII 码 中 包含 美元 符号 ， 而 
英镑 符号 怎么 找 不 到 呢 ? 还 有 西欧 国家 语言 中 用 到 的 重音 符号 在 哪里 ? 更 别 说 使 用 非 拉 
丁字 母 的 希腊 文 ( Greek)、 阿 拉 伯 文 ( Arabic )、 希 伯 来 文 ( Hebrew ) 和 西里 尔 文 ( Cyrillic ) 
等 欧洲 国家 了 。 此 外 ， 印 度 及 东南 亚 地 区 用 到 的 婆罗 门 手 记 、 北 印度 的 Devanagari 方言 、 
孟加拉 语 、 泰 语 、 西 藏 语 也 并 没有 在 ASCII 码 中 出 现 。 简 单 的 7 位 编码 在 面 对 数 以 万 计 
的 中 国 、 日 本 、 韩 国 的 象形 文字 ， 以 及 奇怪 的 朝鲜 文 音 节 时 也 显得 力不从心 。 


在 ASCII 码 的 发 展 历程 中 ， 尽 管 没 有 在 引入 非 拉丁 字母 方面 做 过 工作 ， 但 开发 者 也 一 
直 在 积极 思考 与 改进 编码 系统 ， 使 其 适用 于 其 他 国家 。 根 据 公 布 的 ASCII 码 标准 ， 有 10 个 
ASCII 码 保留 位 (40h、5Bh、5Ch、5Dh、5Eh、60h、7Bh、7Ch、7Dh 和 7Eh ) 可 被 重新 定 
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义 ， 这 样 就 便于 特定 国家 的 使 用 。 另 外 ， 英 镑 符号 〈 上 ) 可 以 在 需要 时 替换 特殊 符号 (#)， 
通用 货币 符号 (5 ) 可 以 在 需要 时 替换 美元 符号 ($ )。 当 然 ， 为 使 得 这 一 替换 过 程 不 发 生 混 
淆 ， 如 果 在 文本 文件 中 使 用 了 这 些 重 定义 的 符号 ， 相 关 人 员 都 必须 知道 这 些 变化 。 


大 多 数 计 算 机 系统 采用 8 位 编码 来 存储 字符 ， 我 们 也 自然 地 想到 设计 一 种 扩展 的 
ASCII 字符 集 ， 这 样 可 以 包含 256 个 字符 ， 比 原先 扩展 了 一 倍 。 在 这 种 字符 集中 ， 编 码 
00h~ 7Fh 与 原 ASCII 码 保持 一 致 ; 编码 80h~ FFh 可 以 用 来 引入 其 他 字符 。 这 项 技术 已 
经 被 用 来 定义 附加 的 字符 编码 ， 比 如 前 面 提 到 过 的 重音 字母 以 及 非 拉 丁字 母 。 下 面 这 个 
例子 是 对 96 个 额外 字符 的 ASCII 码 扩 展 , 称 为 第 1 号 拉丁 字母 表 ( Latin Alphabet No. 1 )， 
其 中 包括 A0h~ FFh 字符 编码 。 在 该 表 中 , 每 个 字符 的 十 六 进 制 编码 的 高 半 字 节 由 第 一 行 
给 出 ， 低 半 字 节 由 第 一 列 给 出 ， 如 下 表 所 示 。 i 


编码 A0h 对 应 的 字符 为 不 中 断 空格 (No-Break Space )。 通 常 计算 机 在 对 文本 进行 排 
版 时 ,会 将 其 划分 为 行 和 了 段 , 行 与 行 之 间 以 空格 符号 区 分 ( 空格 所 对 应 的 ASCII 码 为 20h )。 
编码 A0h 显示 为 空格 ,但 是 并 不 表示 行 与 行 之 间 被 断 开 。 比 如 在 “WW I” 这 样 一段 文 
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re 编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


de ee te ee ne op 
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字 中 就 可 以 使 用 不 中 断 空格 。 编 码 ADh 被 定义 为 软 连 字符 ( soft hyphen )， 它 的 用 途 是 连 ， 
接 同 一 单词 之 间 的 音节 ， 在 一 个 单词 被 不 得 已 划分 在 两 行 时 就 会 用 到 它 。 


只 可 惜 问题 也 随 之 而 来 ， 近 几 十 年 来 出 现 了 许多 不 同 版 本 的 扩展 的 ASCII 码 ， 多 个 
不 同 的 版 本 严重 影响 了 编码 的 一 致 性 ,导致 了 混 奖 和 不 兼容 。ASCII 码 被 扩展 到 极致 ， 有 
的 其 至 可 以 对 中 文 、 日 文 和 韩文 进行 编码 。 其 中 有 一 种 流行 的 编码 一 一 Shift-JIS， 即 日 本 
工业 标准 (Japanese Industrial Standard ), 利用 81h ~ 9Fh 表示 双 字 节 字 符 编码 的 初始 字 节 。 
通过 这 种 手段 ，Shift -JIS 可 对 额外 的 约 6000 个 字符 进行 编码 。 只 可 惜 Shift-JIS 并 不 是 唯 
一 的 采用 这 种 技术 的 编码 系统 。 在 亚洲 地 区 ， 还 有 三 个 类 似 的 双 字 节 字 符 编码 系统 
(double-byte character sets，DBCS ) 同样 也 很 流行 。 


双 字 节 字 符 集 的 确 有 很 多 版 本 ， 但 兼容 性 并 不 是 它 最 主要 的 问题 。 它 的 另 一 个 缺陷 
是 ， 一 些 字 符 ， 特 别 是 通用 的 ASCII 码 字符 ， 是 用 单个 字 节 编 码 表示 的 ， 相 比 而 言 ， 成 
二 上 万 的 象形 文字 则 是 双 字 节 编 码 ， 这 在 无 形 之 中 增加 了 使 用 这 种 字符 集 的 难度 。 


业界 一 直 有 一 个 目标 ， 那 就 是 建立 一 个 独一无二 的 字符 编码 系统 ， 它 可 以 用 于 世界 
上 所 有 语言 文字 ， 从 1988 年 开始 ， 几 大 著名 计算 机 公司 合作 研究 出 一 种 用 来 替代 ASCII 
码 的 编码 系统 , 取 名 为 Unicode 统一 化 字符 编码 标准 ), 相 对 于 ASCII 的 7 位 编码 ,Unicode 
采用 了 16 位 编码 ,每 一 个 字符 需要 2 个 字 节 。 也 就 是 说 Unicode 的 字符 编码 范围 为 0000h~ 
FFFFh， 总 共 可 以 表示 65,536 个 不 同 字符 。 全 世界 所 有 的 人 类 语言 ， 尤 其 是 经 常 出 现在 计 
通信 过 程 中 的 语言 ， 都 可 以 使 用 同一 个 编码 系统 ， 而 且 这 种 系统 还 具备 很 高 的 扩展 性 。 


Unicode 编码 其 实 并 不 是 从 零 开 始 设计 的 , 前 128 个 字符 编码 一 一 即 0000h ~ 007Fh 一 
一 与 ASCII 码 是 一 致 的 。Unicode 编码 中 的 00A0h ~ 00FFh 与 先前 讲 到 的 第 1 号 拉丁 字母 
表 是 一 致 的 。 全 世界 很 多 标准 也 被 一 同 收录 在 Unicode 中 。 


尽管 相对 于 之 前 讲 过 的 一 些 字 符 编 码 系统 , 可 以 说 Unicode 做 出 了 有 效 地 改进 , 但 这 
也 不 能 确保 它 被 全 世界 广泛 采纳 。ASCII 码 ， 包 括 数 不 清 的 有 一 点 小 缺陷 的 扩展 ASCII 
码 已 经 在 计算 机 领域 根深 蒂 固 ， 想 一 下 子 就 取代 它们 并 不 是 轻而易举 的 。 


对 于 Unicode 来 讲 ， 它 唯一 的 问题 ， 就 是 它 改变 了 字符 与 存储 空间 之 间 “ 单 字符 ， 单 
字 节 ”的 等 价 对 应 关系 。 采用 ASCII 编码 方式 存储 的 著作 《怒火 之 花 》 其 所 占据 的 存储 空 
间 约 为 1 MB。 而 如 果 采 用 Unicode 编码 ， 约 占 2 MB。 为 了 使 编码 系统 兼容 ，Unicode 在 存 
储 空间 上 付出 了 相应 的 代价 。 


一 
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在 一 台 计 算 机 中 ， 
访问 存储 器 ( Random Access Memory，RAM ) 也 是 计算 机 不 可 或 缺 的 部 件 ， 它 存放 着 处 


理 器 要 执行 的 机 器 代码 指令 。 通过 怎样 的 方法 才能 把 指令 加 载 到 RAM 中 ?怎样 才能 把 程 
序 的 结果 变 得 可 见 呢 ?或 许 你 一 下 子 就 想到 了 输入 设备 ( Input Device ) 利 输出 设备 ( Output 


Device )。 回 想 一 下 前 面 讲 过 的 内 容 ，RAM 是 易 失 性 存储 器 一 换言之， 当 掉 电 的 时 候 其 


央 处 理 器 无 疑 是 最 重要 的 部 件 ， 但 它 并 不 是 唯一 的 部 件 。 随 机 


中 的 内 容 就 会 丢失 。 所 以 ， 长 期 存储 设备 也 是 一 台 计算 机 必 不 可 少 的 部 件 ， 只 有 这 样 ， 
代码 和 数据 才能 够 被 永久 保存 ， 不 会 因为 掉 电 而 丢失 重要 的 数据 。 


搭建 一 台 完 整 的 计算 机 还 需要 很 多 集成 电路 ， 这 些 集成 电路 都 必须 挂 载 ( mounted ) 
到 电路 板 上 。 在 一 些小 型 的 机 器 中 , 一块 电路 板 足 以 容纳 所 有 的 集成 电路 ,但 这 种 情况 
并 不 常见 。 我 们 通常 所 看 到 的 是 另 一 种 情况 : 计算 机 中 各 部 件 按照 功能 被 分 别 安装 在 两 
个 或 更 多 的 电路 板 上 。 这 些 电路 板 之 间 通 过 总 线 (bus ) 通信 。 如 果 对 总 线 做 一 个 简单 的 


这 


概括 ， 可 以 认为 总 线 就 是 数字 信号 的 集合 ， 而 这 些 信 号 被 提供 给 计算 机 上 的 每 块 电路 板 。 
通常 把 这 些 信号 划分 为 如 下 四 类 。 


se 地 址 信号 。 这 些 信号 是 由 微 处 理 器 产生 ， 通 常用 来 对 RAM 进行 寻 址 操作 ， 当 然 
也 可 以 用 来 对 连接 到 计算 机 的 其 他 设备 进行 寻 址 操作 。 


一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


! 


as 数据 输出 信号 。 这 些 信号 也 是 由 微 处 理 器 产生 的 ， 用 来 把 数据 写 入 到 RAM 或 其 
他 设备 。 这 里 特别 要 注意 区 分 术语 输入 〈input ) 和 输出 〈output )， 来 自 微 处 理 器 
的 数据 输出 信号 会 变 成 RAM 和 其 他 设备 的 数据 输入 信号 。 

。 数据 输入 信号 。 这 些 信号 是 由 计算 机 的 其 他 部 分 提供 的 ， 并 由 微 处 理 器 读 取 。 通 
常情 况 下 ， 数 据 输 入 信号 由 RAM 输出 ， 这 就 解释 了 微 处 理 器 是 怎样 从 内 存 中 读 
取 内 容 的 。 其 实 ， 其 他 部 件 也 可 以 给 微 处 理 器 提供 数据 输入 信和 号。 

”控制 信号 。 这 些 信 号 是 多 种 多 样 的 ， 通 常 与 计算 机 内 所 用 的 特定 的 微 处 理 器 相对 
应 。 控 制 信号 可 以 产生 于 微 处 理 器 ， 也 可 以 由 与 微 处 理 器 通信 的 其 他 设备 产生 。 
比如 ， 当 微 处 理 器 要 把 一 些 数据 写 入 到 特定 内 存单 元 时 ， 它 所 使 用 的 信号 就 是 控 
制 信号 。 

还 有 一 点 需要 说 明 : 总 线 还 可 以 为 计算 机 上 不 同 电路 板 供电 。 


回顾 一 下 总 线 的 发 展 历程 ,在 家 用 计算 机 领域 ,早期 比较 流行 的 就 是 S-100 总 线 , 1975 
年 第 一 台 家 用 计算 机 MITS Altair 就 率先 采用 了 这 种 总 线 。 尽 管 一 开始 ，S-100 总 线 只 是 
基于 8080 微 处 理 器 的 , 后 来 经 过 改进 , 也 开始 适用 于 其 他 处 理 器 , 例如 6800。 一 块 S-100 
电路 板 的 规格 是 5.3x10 英寸 ， 其 中 有 一 边 是 要 插 到 一 个 播 槽 上 的 ， 这 个 插 槽 有 100 个 连 
接 器 (这 就 是 名 为 S-100 的 原因 )。 


每 台 S-100 计算 机 都 有 一 块 很 大 的 被 称 为 母 板 ( motherboard 或 mainboard ) 的 电路 板 ， 
它 有 若干 相互 连接 的 S-100 总 线 插 横 (可 能 有 12 个 )。 有 时 候 ， 这 些 播 槽 也 被 称 为 扩展 插 
模 ( expansion slots )。S-100 电路 板 (也 称 为 扩展 板 ，expansion boards ) 就 插 在 这 些 插 槽 
中 。8080 微 处 理 器 及 支持 芯片 【第 19 章 提 到 过 的 其 中 的 一 些 ) 分 布 在 一 块 S-100 电路 板 
上 ， 而 RAM 分 布 在 一 块 或 多 块 其 他 电路 板 上 。 


S-100 总 线 是 专门 为 8080 芯片 而 设计 的 ， 有 16 个 地 址 信号 ，8 个 数据 输入 信号 及 8 
个 数据 输出 信号 (仔细 回忆 一 下 ，8080 本 身 并 不 区 分 数据 输入 和 输出 信号 ， 这 项 工作 是 
由 电路 板 上 的 其 他 支持 芯片 完成 的 )。 总 线 上 也 含有 8 个 中 断 信号 , 其 他 设备 需要 CPU 立 
即 做 出 响应 时 ， 便 会 产生 这 些 信 号 。 下 面 我 们 看 一 个 例子 〈 本 章 的 后 面 也 要 讲 到 )， 当 某 
个 按键 按 下 时 ， 键 盘 可 能 就 会 产生 一 个 中 断 信 号 。 接 下 来 8080 会 执行 一 段 小 程序 ， 检 测 
出 是 什么 按键 被 按 下 ， 并 做 出 响应 。 通 常 ， 在 安装 了 8080 的 电路 板 上 有 一 个 被 称 为 Intel 
8214 优先 级 中 断 控制 单元 的 芯片 ， 就 是 专门 用 来 处 理 中 汤 的 。 当 中 断 发 生 时 ， 这 个 芯 
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会 产生 一 个 中 断 信号 并 送 给 8080。8080 识别 出 这 个 中 断后 ， 此 芯片 就 会 提供 一 个 RST 
(Restart， 重 启 ) 指令 ， 在 这 条 指令 的 作用 下 ， 微 处 理 器 会 把 当前 程序 计数 器 的 值 保存 下 
来 ， 并 依据 中 断 类 型 ， 跳 转 到 地 址 0000h、0008h、0010h、0018h、0020h、0028h、0030h 
或 0038h 处 执行 。 


如 果 你 在 设计 一 个 新 的 计算 机 系统 ， 而 这 个 系统 中 采用 新 的 总 线 类 型 ， 你 可 以 选择 
把 总 线 规范 公布 于 众 〈 也 可 以 通过 其 他 方式 发 布 出 去 ) 或 者 使 其 保密 ， 决 定 权 在 于 你 。 


一 旦 一 条 指定 总 线 的 规范 公布 开 来 ， 其 他 制造 商 一 一 称 为 第 三 方 ( third-party ) 制造 
商 一 一 就 可 以 设计 并 销售 采用 了 这 种 总 线 的 扩展 板 了 。 这 些 额 外 扩展 板 不 仅 加 强 了 计算 机 
的 实用 性 ， 还 使 其 更 加 满足 实际 需求 。 计 算 机 的 销售 情况 越 好 ， 扩 展板 的 市 场 前 景 也 就 
越 好 。 正 是 由 于 这 个 原因 ， 设 计 者 在 设计 多 数 小 型 计算 机 系统 时 ， 都 会 坚持 开放 体系 结 
构 ( Open Architecture ) 的 原则 ， 这 样 一 来 ， 其 他 制造 商 就 可 以 生产 计算 机 的 外 设 。 最 终 
会 有 一 条 总 线 成 为 工业 标准 。 在 今天 ,“ 标 准 ”已 经 成 为 个 人 计算 机 产业 的 一 个 重要 组 成 
部 分 。 


1981 年 秋 ， 最 著名 的 开放 体系 结构 个 人 计算 机 一 一 IBM 的 PC 问世 。IBM 公布 了 PC 
的 技术 参考 资料 technical reference )， 里 面包 含 了 整 台 计 算 机 的 全 部 电路 图 ，IBM 为 其 
制造 的 扩展 板 的 资料 也 在 其 中 。 这 个 手册 可 是 很 重要 的 资料 ， 它 的 出 现 使 得 很 多 制造 商 
可 以 生产 自己 的 PC 扩展 板 ， 实 际 上 ， 这 创造 出 了 整个 PC 的 克隆 体 一 一 其 实 与 IBM 的 
PC 几乎 完全 相同 ， 运 行 的 软件 也 一 样 。 


在 如 今 的 桌面 计算 机 领域 ， 从 起 初 的 IBM 的 PC 发 展 而 来 的 计算 机 数量 庞大 ， 占 据 
约 90% 的 市 场 份额 。 尽 管 BM 本 身 只 占 很 小 一 部 分 ， 但 事实 上 ， 如 果 起 初 的 PC 采用 的 
是 封闭 体系 结构 ( closed architecture ) 且 设 计 是 私有 化 (proprietary ) 的 ,其 所 占 的 市 场 份 
额 会 更 少 。 苹 果 公 司 的 麦 金 托 什 《Macintosh ) 起 初 采用 的 是 封闭 体系 结构 ， 尽 管 也 曾 部 
分 考虑 过 开放 的 问题 , 这 也 就 解释 了 为 什么 Macintosh 在 如 今 的 桌面 计算 机 市 场 上 只 占有 
不 到 10% 的 份额 。( 请 记 住 这 一 点 : 一 个 计算 机 系统 可 以 是 在 开放 体系 结构 下 设计 的 ,也 
可 以 是 在 封闭 体系 结构 下 设计 的 ,无论 是 哪 种 情况 ， 其 他 公司 都 可 以 为 其 设计 软件 。 但 
也 有 例外 的 情况 ， 某 些 视频 游戏 的 开发 商会 限制 其 他 公司 开发 其 专用 系统 上 的 软件 )。 


最 初 的 IBM PC 采用 的 是 Intel 8088 微 处 理 器 ,可 以 寻 址 1 MB 的 存储 单元 。 虽 然 8088 
内 部 是 一 个 16 位 的 微 处 理 器 ,但 外 部 却 只 能 寻 址 8 位 的 存储 器 。 工 业 标准 体系 结构 
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( Industry Standard Architecture，ISA ) 总 线 ， 是 IBM 为 最 初 的 PC 设计 的 。 扩 展板 上 有 62 
针 的 连接 插头 。 有 20 个 地 址 信号 ，8 个 复 用 的 数据 输入 /输出 信号 ，6 个 中 断 请 求 信号 及 
3 个 直接 存储 器 访问 (Direct Memory Access, DMA ) 请求 信号 。DMA 可 以 使 存储 设备 (本 
章 最 后 我 们 会 讲 到 ) 快速 地 执行 存储 操作 ， 这 比 采用 其 他 方法 快 得 多 。 通 常情 况 下 ， 所 
有 读 / 写 内 存 的 操作 都 是 由 微 处 理 器 来 完成 的 ， 但 采用 了 DMA 后 ， 其 他 设备 可 以 不 通过 
微 处 理 器 而 获得 总 线 的 控制 权 ， 进 而 直接 对 内 存 进行 读 写 。 


在 S-100 系统 中 ,所 有 的 部 件 都 安放 在 扩展 板 上 。 就 拿 IBM PC 来 说 , 微 处 理 器 、 支 
持 芯 片 及 一 些 RAM 都 安装 在 一 块 系统 板 上 ， 系 统 板 〈system board ) 是 IBM 的 “内 部 称 
呼 ”， 但 它 常常 也 被 称 为 母 板 或 主板 。 


1984 年 ，IBM 推出 了 个 人 计算 机 AT， 采 用 的 是 16 位 的 Intel 80286 微 处 理 器 ， 这 个 
微 处 理 器 可 以 寻 址 16 MB 的 存储 单元 。IBM 保留 了 原 有 的 总 线 , 但 添加 了 一 个 36 针 的 插 
槽 。 这 个 插 槽 包括 7 个 地 址 信号 ( 其实 只 需 4 个 )、8 个 数据 输入 /输出 信号 、5 个 中 断 请 
求 信 号 以 及 4 个 DMA 请 求 信号 ， 这 些 信号 都 是 新 增 的 。 

微 处 理 器 所 使 用 的 数据 宽度 ( 从 8 位 到 16 位 再 到 32 位 ) 和 输出 的 地 址 信号 的 数目 
在 不 断 增长 ， 当 这 些 超出 总 线 的 承受 能 力 时 ， 总 线 就 需要 升级 换代 了 。 如 果 微 处 理 器 的 
处 理 速度 很 快 时 ， 也 会 出 现 这 种 情况 。 早 期 的 总 线 是 为 当时 的 微 处 理 器 而 设计 的 ， 它 们 
的 时 钟 频 率 -一 般 是 几 兆 赫兹 而 不 是 几 百 兆赫 兹 。 如 果 设 计 出 来 的 总 线 不 适合 高 速 传输 的 
话 ， 就 会 出 现 射频 干扰 ( RFI )， 这 会 使 附近 的 收音 机 和 电视 机 产生 静电 或 其 他 噪声 。 


1987 年 ，IBM 推出 了 微 通 道 体 系 结构 ( Micro Channel Architecture ，MCA ) 总 线 。 这 
种 总 线 的 某 些 部 分 已 经 成 为 IBM 的 专利 ， 如 果 其 他 公司 使 用 这 种 总 线 ，IBM 就 会 从 中 收 
取 授 权 费 用 。 也 许 就 正 是 由 于 这 个 原因 ，MCA 才 没 能 成 为 一 种 工业 标准 。 然 而 就 在 1988 
年 ，9 家 公司 (并 不 包括 IBM ) 联合 推出 的 32 位 EISA (Extended Industry Standard 
Architecture ) 总 线 取 代 了 MAC， 成 为 了 工业 标准 。 近 几 年 ，Intel 公司 设计 的 外 围 部 件 互 
连 (PCI) 总 线 已 普遍 使 用 在 PC 兼容 机 上 。 


计算 机 上 的 各 种 不 同 的 部 件 是 如 何 工作 的 呢 ? 为 了 能 更 好 地 理解 ， 让 我 们 再 次 回 到 
20 世纪 70 年 代 中 期 去 看 一 看 。 想 象 一 下 ， 我 们 正在 为 Altair 设计 电路 板 ， 或 者 是 在 为 自 
己 设计 的 8080 或 6800 计算 机 做 这 样 的 事情 。 我 们 不 仅 要 考虑 为 计算 机 设计 一 些 存 储 器 ， 
用 键盘 作为 输入 ， 用 电视 机 作为 输出 ; 还 要 考虑 关上 计算 机 时 ， 如 何 把 存储 器 中 的 内 容 
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保存 下 来 。 如 何 把 这 些 部 件 添 加 到 计算 机 中 昵 ?9 下 面 就 来 看 看 能 实现 这 个 功能 的 各 种 接 
口 (Interface )。 


现在 回想 一 下 第 16 章 所 讲 的 内 容 ，RAM 阵列 有 地 址 输入 、 数 据 输入 ， 以 及 数据 输 
出 信号 ， 男 外 还 有 一 个 用 来 把 数据 写 入 存储 器 的 控制 信号 。RAM 阵列 能 存放 的 数据 的 数 
量 是 和 地 址 输入 信号 的 个 数 有 关 的 ， 它 们 之 间 有 着 如 下 的 关系 : 


RAM 阵列 中 数字 的 个 数 =2 


讲 到 这 里 你 可 能 会 问 ， 数 据 输 入 、 输 出 信号 又 有 怎样 的 作用 呢 ? 其 实 它们 决定 着 所 
存储 的 数值 的 大 小 ( 位 数 )。 

20 世纪 70 年 代 中 期 ，2102 是 用 于 家 用 计算 机 的 一 款 流 行 的 存储 器 芯片 。 其 管 脚 分 
布 如 下 图 所 示 。 


My Mg By CS DO BL SY 


4 
2102 
i 2 3 4 5 5 7 § 

让 ys RR 让， A 入 Ay 
它 也 是 MOS ( metal-oxide semiconductor ) 家 族 中 的 一 员 ， 与 8080 和 6800 微 处 理 器 所 采 
用 的 技术 相同 。MOS 半导体 管 很 容易 与 TTL 芯片 连接 起 来 ; 通常 情况 下 ,其 内 部 晶体 管 
的 密度 要 比 TTL 高 ， 但 速度 却 不 如 TIL 快 。 


这 个 心 片 存储 容量 可 以 达到 1024 位 ， 这 个 数值 可 以 根据 地 址 信号 (A0~ A9 )、 数 据 
输出 (DO ) 和 数据 输入 (DI) 信号 (输入 和 输出 复 用 一 个 信号 线 ) 的 数目 计算 出 来 。 你 
所 使 用 2102 芯片 型 号 不 同 ， 访 问 时 间 (read access time， 指 从 芯片 接收 到 地 址 信息 到 输 
出 有 效 数据 所 需 的 时 间 ) 也 是 各 有 差异 ， 从 350 ns ~ 1000 ns 不 等 。 当 需要 从 存储 器 中 读 
取 数 据 时 ，R/W ( 读 / 写 ) 信号 置 1; 当 向 芯片 中 写 入 数据 的 时 候 ， 这 个 信号 要 置 0， 而 
且 至 少 要 持续 170~ 550 ns 的 时 间 ， 也 是 由 所 使 用 的 2102 芯片 的 型 号 决定 的 。 


这 里 我 们 不 得 不 提 到 的 一 个 信号 就 是 CS 信号 ， 也 称 片 选 信号 。 该 信号 置 1 时 ， 芯 片 
不 被 选中 ， 意 思 就 是 说 ， 不 会 响应 R/W 信和 号。 其实 ，CS 信号 的 作用 不 止 这 些 ， 对 芯片 
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还 有 其 他 重要 的 作用 ， 下 面 我 们 将 简单 描述 一 下 。 

想 想 看 ， 若 让 你 为 8 位 的 微 处 理 器 组 织 存储 器 的 话 ， 你 会 怎么 做 昵 ? 是 选择 按 8 位 
存储 形式 , 还 是 1 位 存储 形式 ? 你 肯定 会 选择 前 者 。 如 果 想 存储 整个 字 节 ， 则 至 少 需要 8 
个 这 样 的 2102 芯片 。 具 体 的 做 法 就 是 ， 把 8 个 芯片 对 应 的 地 址 信号 、R/W 及 CS 信号 连 
接 起 来 ， 如 下 图 所 示 。 

地 址 


数据 输入 -EM 1024x8 RAM bo 数据 输出 


实际 上 ， 这 是 一 个 1024x8 位 的 RAM 阵列 ， 或 者 说 是 容量 为 1 KB 的 RAM。 


把 存储 器 芯片 安装 在 一 块 电路 板 上 ， 这 是 很 符合 实际 的 做 法 。 那 么 ， 到 底 一 块 电路 
板 上 能 安装 多 少 块 这 样 的 芯片 呢 ? 如 果 是 紧 紧 排 列 在 一 起 的 话 ， 一 块 S-100 板 就 能 容纳 
64. 个 。 这样 一 来 , 就 提供 了 一 个 8 KB 的 存储 空间 。 一 般 我 们 不 这 样 做 , 更 合适 的 方法 是 ， 
用 32 个 芯片 组 成 一 个 4 KB 的 存储 器 。 为 了 存储 完整 的 字 节 ， 而 连接 在 一 起 的 芯片 的 集 
合 ， 称 为 存储 体 (bank )。 例 如 , 一 个 4KB 大 小 的 存储 器 板 就 由 4 个 存储 体 组 成 ， 而 每 
个 存储 体 又 包含 8 个 芯片 。 


8 位 微 处 理 器 ,例如 8080、6800， 有 16 位 地 址 ， 可 用 来 寻 址 64 KB 的 存储 空间 。 如 
果 你 制作 了 一 个 包含 4 个 存储 体 、 大 小 为 4 KB 的 存储 器 板 ， 则 存储 器 板 上 的 16 位 地 址 
信号 就 有 如 下 所 示 的 功能 。 
站 5 Ai Al3 Al2 站 11 B10 A As Ar Ac As A4 A3 Al A1 Ag 
选择 存储 ”选择 存 寻 址 RAM 
器 板 储 体 
下 面 详细 解释 一 下 这 16 位 地 址 信号 。A0 ~ A9 直接 与 RAM 芯片 相连 接 ; A10 和 All 
用 来 选择 4 个 存储 体 中 要 被 寻 址 的 那 一 个 ;A12 ~ A15 确定 哪些 地 址 申请 用 这 块 存储 器 板 ， 
换言之 , 就 是 这 块 存储 器 板 响 应 哪些 地 址 。 微 处 理 器 整个 存储 空间 的 大 小 是 64 KB, 被 划 
分 成 16 个 不 同 的 区 域 ， 每 个 区 域 的 大 小 是 4 KB， 我 们 设计 的 4KB 存储 器 板 占用 了 其 中 
一 个 区 域 。 这 16 个 区 域 划 分 情况 如 下 。 
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0000h ~ OFFFh 
1000h ~ 1FFFh 
2000h ~ 2FFFh 


F000h ~ FFFFh 


举例 说 明 , 假定 4 KB 存储 器 板 使 用 了 A000h ~ AFFFh 地 址 区 域 。 这 就 意味 着 ,第 一 个 存 
储 体 占用 了 地 址 A000h ~ A3FFh， 第 二 个 占用 了 地 址 A400h ~ A700h， 第 三 个 占用 了 地 址 
A800h ~ ABFFh， 独 下 的 AC00h ~ AFFFh 地 址 空间 分 给 了 第 四 个 存储 体 。 


你 完全 可 以 制作 一 块 4KB 存储 器 板 , 在 用 到 它 的 时 候 再 灵活 确定 其 地 址 范围 。 要 获 
得 这 样 的 灵活 性 ， 可 以 使 用 一 种 名 为 双 列 直 插 式 封 装 ( dual inline package，DIP ) 开关 的 
器 件 。 在 DIP 中 ， 有 一 系列 极 小 的 开关 (从 2 到 12 个 不 等 )。DIP 是 可 以 插 在 标准 的 IC 
插 权 中 的 ， 如 下 图 所 示 。 


在 一 种 称 为 比较 器 (comparator ) 的 电路 中 ， 你 可 以 把 这 个 开关 和 总 线 上 地 址 信号 的 高 4 
位 连接 起 来 ， 就 像 下 面 这 样 。 


EW es yy 
\ ed Fawat 
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编码 一 -隐匿 在 计算 机 软 硬 件 背后 的 语言 


汕 


回想 一 下 前 面 讲 过 的 内 容 ， 异 或 ( XOR ) 门 电路 在 两 个 输入 端 中 只 有 一 个 是 高 电 平 
时 ， 输 出 才 为 高 电 平 ;， 当 两 个 输入 端 同时 为 低 电 平 或 高 电 平 时 ， 输 出 是 低 电 平 。 


例如 ， 如 果 把 Aa 和 Ais 对 应 的 开关 闭合 ， 就 意味 着 让 存储 器 板 能 响应 存储 器 空间 
A000h ~ AFFFh。 若 总 线 上 的 地 址 信号 Apz、Ab、Auu 和 Ais 与 开关 上 设置 的 值 相同 的 话 ， 
四 个 异 或 (XOR ) 门 的 输出 都 是 0, 或 非 (NOR ) 门 的 输出 为 1， 如 下 图 所 示 。 
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接 下 来 我 们 把 Equal 信号 和 一 个 2-4 译 码 器 联合 起 来 使 用 , 就 能 为 四 个 存储 体 中 的 每 
一 个 都 产生 一 个 CS 信号， 便于 对 存储 体 进行 选择 。 具 体 连 接 图 如 下 图 所 示 。 


3 第 一 个 存储 体 
CS 第 二 个 存 催 体 
55 第 三 个 存储 体 
Rs 第 四 个 存储 体 


例如 ， 若 想 选 择 第 三 个 存储 体 ， 把 Aio、ADn 分 别 置 0 和 1 就 可 以 了 。 


现在 回想 一 下 在 第 16 章 中 阐述 过 的 如 何 组 织 RAM 阵列 ， 这 一 过 程 的 细节 是 十 分 繁 
琐 的 , 你 可 能 会 认为 我 们 还 需要 8 个 4-1 选择 器 , 用 来 从 4 个 存储 体 中 选择 正确 的 数据 输 
出 信号 。 但 我 们 并 没有 这 人 么 做 ， 下 面 来 讨论 下 原因 。 


通常 情况 下 ，TTL 兼容 集成 电路 的 输出 信号 要 么 大 于 2.2V( 多 辑 1 ) 要 么 小 于 0.4V 
( 逻辑 0 )。 试想 一 下 , 如 果 把 输出 信号 连接 起 来 会 发 生 什 么 呢 ? 一 个 集成 电路 的 输出 为 1， 
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另 一 个 集成 电路 的 输出 为 0, 若 把 这 两 个 输出 连接 在 一 起 ,结果 又 是 什么 呢 ? 恐怕 谁 也 无 
法 回答 。 就 是 由 于 这 种 不 确定 性 ， 一 般 不 会 把 集成 电路 的 输出 信号 连接 在 一 起 。 


2102 芯片 的 数据 输出 信号 是 三 态 ( tri-state ) 的 ， 也 就 是 说 ， 除 了 逻辑 0 和 逻辑 1 之 
外 , 数据 输出 信号 还 有 第 三 种 状态 。 我 们 必须 清楚 地 认识 这 种 状态 一 一 它 其 实 是 一 种 “ 真 
空 ” 态 ， 就 像 芯 片 的 引 脚 上 什么 也 没 连 一 样 。 当 片 选 信号 ( CS ) 为 1 的 时 ，2102 芯片 的 
数据 输出 信号 就 会 进入 这 种 状态 。 这 样 一 来 ,我们 可 以 把 4 个 存储 体 相应 的 数据 输出 信 
号 连接 在 一 起 ， 并 且 可 以 把 8 个 输出 复 用 作为 总 线 的 8 个 数据 输入 信号 。 


之 所 以 强调 三 态 输出 的 概念 ， 是 因为 它 对 总 线 的 操作 是 至 关 重 要 的 。 几 乎 所 有 连接 
在 总 线 上 的 器 件 都 使 用 由 总 线 传 递 而 来 的 数据 输入 信号 。 但 不 管 何 时 ， 连 接 在 总 线 上 的 
电路 板 中 只 有 一 个 能 确定 总 线 数据 输入 信号 的 类 型 ， 其 他 电路 板 处 于 三 种 状态 中 的 无 效 


或 许 大 家 听 说 过 ，2102 是 一 款 静 态 随机 访问 存储 器 心 片 ( Static Random Access 
Memory， SRAM )， 它 与 动态 访问 存储 器 (Dynamic Random Access Memory，DRAM ) 
是 不 同 的 。 通 常 对 于 每 1 位 存储 空间 ，SRAM 需要 用 4 个 晶体 管 (在 第 16 章 中 讲 过 将 触 
发 器 作为 存储 器 用 ， 其 用 到 的 好 体 管 更 多 )， 而 DRAM 只 需要 1 个 晶体 管 , 但 DRAM 需 
要 较 复 杂 的 外 围 支持 电路 ， 这 正 是 它 的 缺点 。 


SRAM 芯片 ， 例 如 2102， 在 电源 持续 供电 的 情况 下 ， 其 内 容 就 能 保留 下 来 ; 一 旦 掉 

电 ， 其 内 容 就 会 丢失 。 在 这 方面 DBRAM 和 SRAM 很 类 似 。 但 不 同 的 是 ， DRAM 芯片 在 

使 用 时 需要 定期 访问 其 存储 器 中 的 内 容 ， 尽 管 有 时 并 不 需要 这 些 内 容 。 这 一 过 程 称 之 为 

更 新 (refresh ) 周期 ， 每 秒 钟 都 必须 进行 几 百 次 。 ee 让 某 人 入 睡 而 每 隔 
一 段 时 间 就 用 手 肘 轻 推 他 一 样 。 


尽管 业界 在 使 用 DRAM 上 有 些 争论 , 但 近年 来 ，DRAM 芯片 的 容量 日 益 增加 ， 使 得 
DRAM 最 终 成 为 标准 。1975 年 ,英特尔 公司 推出 了 一 一 款 DRAM 芯片 ， 容 量 为 16,384 位 。 
其 实 ，DRAM 芯片 在 容量 上 基本 每 三 年 翻 两 番 ， 符 合 摩尔 定律 。 如 今 ， 计 算 机 主板 上 一 
般 都 配备 内 存 插 梓 ， 这 些 内 存 插 权 可 以 容纳 几 块 小 存储 器 板 ， 分 为 单列 直 插 内 存 模块 
( single inline memory modules，SIMM ) 和 双 列 直 插 内 存 模块 ( dual inline memory module， 
DIMM ) 两 种 , 里 面包 含 好 几 个 DRAM 芯片 。 如今 , 花费 不 到 300 美元 就 可 以 买 到 128 MB 
的 DIMM 了 。 
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既然 已 经 知道 如 何 制作 存储 器 板 了 ， 应 该 没有 人 会 把 微 处 理 器 的 整个 存储 空间 都 分 
配给 存储 路 ， 必 须 留 些 空间 给 输出 设备 。 


电子 射线 管 ( cathode-ray tube，CRT ) 一 一 20 世纪 上 半 个 世纪 , 在 家 庭 中 常见 的 物件 ， 
它 从 外 观 上 看 就 像 电视 机 一 样 一 一 已 经 成 为 最 常见 的 计算 机 输出 设备 了 。 我 们 称 连 接 到 计 
算 机 上 的 CRT 为 视频 显示 器 ( video display ) 或 监视 器 (monitor )， 而 称 可 以 为 视频 显示 
器 提供 信和 号 的 电子 元 件 为 视频 适配器 (video display adapter )。 通 常 在 计算 机 中 ， 视 频 适 
配器 是 独立 存在 的 ， 它 们 拥有 自己 的 电路 板 ， 也 就 是 我 们 常 说 的 显卡 〈video board )。 


表面 上 看 来 ， 视 频 显 示 器 或 电视 机 的 二 维 图 像 很 复杂 ， 但 实际 上 它 是 由 一 束 连 续 的 
光束 射线 迅速 扫描 屏幕 而 形成 的 。 射 线 从 屏幕 左上 角 开 始 ， 从 左 到 右 进 行 扫描 ， 到 达 屏 
幕 边 缘 后 义 折 回 向 左 ， 进 行 第 二 行 扫 描 。 我 们 称 每 一 个 水 平行 为 扫描 行 ( scan line )， 称 
射线 回 到 每 个 扫描 行 的 开始 位 置 为 水 平 回 归 (horizontal retrace )。 当 完成 了 对 最 后 一 行 的 
扫描 时 ,射线 不 会 停 下 来 , 它 会 从 屏幕 的 右 下 角 返 回 到 屏幕 的 左上 角 ( 垂直 回归 , vertical 
retrace )， 并 重复 上 一 过 程 。 就 拿 美 国 的 电视 信号 来 说 ， 每 秒 钟 要 进行 60 次 ( 称 为 场 频 ， 
field rate ) 这 样 的 扫描 。 由 于 扫描 的 速度 很 快 ， 所 以 不 会 看 到 图 像 出 现 闪 烁 的 现象 。 


电视 机 采用 的 是 隔行 (interlaced) 扫 描 技 术 , 情况 要 复杂 些 。 我 们 先 来 看 一 下 帧 ( frame 2 
的 概念 ， 帧 是 一 个 完整 的 静态 视频 图 像 ， 两 个 场 ( field ) 才能 形成 一 个 单独 的 帧 。 整 个 帧 
的 扫描 线 分 由 两 个 场 来 完成 一 一 偶数 扫描 线 属 于 第 一 个 场 , 奇数 扫描 线 属于 第 二 个 场 。 这 
里 要 说 明 一 下 水 乎 扫描 频率 (horizontal scan rate ) 的 概念 ， 即 扫描 每 个 水 平行 的 速率 ， 例 
如 15,750 Hz。 把 这 个 数 除 以 60 Hz, 结果 是 262.5 行 ， 这 正 是 每 个 场所 包含 的 扫描 线 的 数 
目 ， 整 个 帧 的 扫描 线 的 数目 是 场 的 两 倍 ， 也 即 525 行 。 


不 管 隔行 扫描 技术 是 怎样 实现 的 ， 组 成 视频 图 像 的 连续 射线 都 是 由 一 个 连续 的 信号 
所 控制 。 虽 然 一 套 电 视 节 目的 声音 和 图 像 部 分 是 一 起 播 出 的 ， 但 若 想 把 它们 广播 出 去 或 
者 通过 有 线 电 视 系 统 传送 出 去 ， 就 不 得 不 分 开 进 行 。 这 里 所 说 的 视频 信号 其 实 与 VCR、 
录像 机 、 摄 像 机 及 一 些 电 视 机 上 的 视频 输入 或 输出 信号 是 一 样 的 。 


黑白 电视 机 的 视频 信号 十 分 简单 且 易于 理解 〈 彩 色 电视 机 要 稍微 复杂 些 )。 每 秒 钟 扫 
描 60 次 , 扫描 信号 包含 一 个 垂直 同步 脉冲 ( vertical sync pulse )， 用 来 指示 一 个 场 的 开始 。 
这 个 脉冲 为 0V， 宽 度 约 为 400 ms。 相 比较 而 言 ， 水 平 同步 脉冲 (horizontal sync pulse ) 
则 用 来 指示 每 个 扫描 行 的 开始 : 视频 信号 为 0 V， 宽 度 为 5 ms， 每 秒 钟 出 现 15,750 次 。 
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在 两 个 水 平 同步 脉冲 之 间 , 信号 的 电压 是 在 0.5~ 2.0V 范围 内 变化 的 ,其 
” 色 ，2.0V 表示 是 白色 ,处 于 两 者 之 间 的 电压 则 表示 
于 上 述 原 
然 在 秋 直 方向 上 , 图 
图 像 的 可 视 强度 。 这 

变化 频率 是 有 上 限 的 ， 


色 ， 


是 受 带宽 限制 


正 是 


忆 ， 电 视 才 会 出 现 


像 被 分 为 525 行 ， 


0.5V 表示 黑 


主 的 灰 度 。 


部 分 是 数字 图 像 、 
日 每 个 扫描 行 的 


部 分 却 是 模拟 图 像 的 情 
, 压 却 是 连续 变化 的 一 一 用 来 模拟 


| 
是 


-不 等 了 说 ， 电压 


在 通 信和 领域 


的 。 以 电视 机 为 例 ， 带 


可 以 随意 地 3 


化 。 事 实 上 ， 电 视 机 能 响应 的 信和 号 


我 们 称 这 一 上 多 


宽 限 制 了 视频 信号 从 黑 到 白 然 后 又 回 到 入 


展 为 电视 村 带宽 ( bandwidth )。 


其 重要 的 概念 ， 


某 个 特定 的 传输 媒介 能 够 传输 的 信息 量 都 
这 一 变化 


的 速率 。 对 于 美国 的 广播 电视 来 说 ， 带 宽大 约 为 42 MHz。 


从 黑 到 


行 有 533 个 像素 。 但 并 
的 远 端 或 射线 的 水 3 


与 水 平方 向 类 人 
部 、 


旦 我 们 把 


视频 显 万 


水 平反 


然后 又 


漠 行 上 像素 的 个 数 是 


:器 连 接 到 计算 机 上 ， 就 不 该 把 它 作为 模拟 和 数字 的 混合 设备 来 
对 待 ， 把 它 看 做 是 完 完全 全 的 数字 设备 更 合适 
方便 地 把 


下 一些 。 从 计算 机 的 角度 来 说， 我 们 可 以 很 


巴 视频 图 像 想 象 成 由 离散 点 组 成 的 矩形 网 格 ， 这 些 离散 点 称 为 像素 〈 这 一 术语 来 


picture element )。 


受 带宽 严格 限制 的 。 在 这 里 ， 我 把 带宽 定义 为 视频 信号 


回 到 黑 的 变化 速率 。 如 组 
秒 420 万 次 的 变化 ， 或 者 一 一 用 


2x4,200,000 除 以 水 平 扫描 速率 15,750 一 一 每 个 水 平 扫描 
不 是 所 有 的 像素 都 可 用 ， 
回归 中 。 这 样 算 来 ， 
以 ， 垂 直方 向 上 525 个 像素 也 不 是 都 可 用 。 
底部 以 及 垂直 回归 期 间 都 会 有 所 损失 。 
赖 于 隔行 扫描 技术 了 ， 垂 直方 向 上 有 着 合理 的 像素 数目 


电视 机 的 带宽 为 42 MHz， 它 就 允许 2 个 像素 每 


约 1/3 的 像素 被 隐藏 了 起 来 一 一 处 于 图 像 
水 平 扫描 行 上 可 用 的 像素 约 为 320 个 。 


原因 是 ， 像 素 在 屏幕 的 顶 
当 计 算 机 采用 电视 机 作为 显示 器 时 ， 就 不 依 
200。 


因此 我 们 可 以 说 , 星期 普通 电视 机 上 的 视频 适配器 的 分 辩 率 为 320x200， 即 水 平方 向 


上 有 320 个 像素 、 垂 直方 向 上 有 200 个 像素 。 
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了 


如 何 确定 上 面 网 格 中 像素 的 总 数 呢 ?” 你 可 以 去 数 一 下 , 也 可 以 简单 地 用 320 乘 以 200 


得 出 结果 64,000。 每 个 像素 可 以 是 黑色 或 白色 ， 或 者 为 某 一 特定 的 颜色 ， 这 要 取决 于 视 
频 适配器 的 配置 。 


现在 我 们 想 在 显示 器 上 显示 出 一 些 文本 字符 ， 那 么 到 底 能 显示 出 多 少 呢 ? 很 明显 ， 
这 取决 于 每 个 字符 所 用 的 像素 数 。 下 面 是 一 种 可 行 的 方法 , 每 个 字符 使 用 8x8 的 网 格 ( 64 
个 像素 )。 


上 图 中 显示 出 的 字符 对 应 的 ASCII 码 在 20h ~ 7Fh 区 间 (在 00h~ 1Fh 的 ASCII 码 字 
符 都 是 无 法 显示 的 字符 )。 


每 个 字符 都 被 定义 为 一 个 7 位 的 ASCII 码 ， 但 每 个 字符 也 与 64 比特 (位 ) 相关 ， 这 
64 比特 决定 了 字符 会 显示 为 什么 样子 。 当 然 ， 你 也 可 以 把 这 64 位 信息 当做 代码 看 待 。 


上 面 我 们 对 字符 进行 了 定义 ， 使 用 这 些 定义 ， 分 辩 率 为 320x200 视频 显示 器 的 每 一 
屏 就 能 显示 25 行 、 每 行 40 个 字符 ， 足 够 把 艾 米 : 洛 威 尔 ( Amy Lowell，1874-1925 ) 的 
一 首 短 诗 显示 出 来 ， 看 看 下 面 的 图 。 
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视频 适配器 中 必须 配置 一 些 RAM， 用 以 存储 所 显示 的 内 容 ; 微 处 理 器 也 必须 能 够 向 
此 RAM 中 写 入 数据 以 改变 显示 器 上 显示 的 内 容 。 更 方便 的 是 ， 这 个 RAM 也 是 微 处 理 器 
存储 空间 的 一 部 分 。 那 么 ， 上 面 描述 的 显示 适配器 需要 多 大 的 RAM 呢 ? 

这 个 问题 并 不 太 好 回答 ! 我 们 只 能 说 ， 结 果 可 能 处 于 1 KB ~192 KB 之 间 。 

我 们 从 最 简单 的 情况 去 考虑 。 怎样 减少 显示 适配器 的 内 存 需求 呢 ? 一 种 方法 是 限制 
适配器 的 功能 ， 让 其 只 显示 文本 。 我 们 已 经 明确 地 知道 ， 视 频 显 示 器 的 每 屏幕 能 显示 25 
行 、 每 行 40 个 字符 ， 也 可 以 说 ， 总 共 能 显示 1000 个 字符 。 这 样 一 来 ， 视 频 卡 上 的 RAM 
只 需 存储 这 1000 个 字符 的 7 位 ASCII 码 。1000X7bit， 大 小 约 为 1024 字 节 ， 即 1 KB。 


字符 生成 器 ( character generator ) 也 是 视频 适配器 板 上 的 一 部 分 ， 包 含 了 所 有 ASCII 
码 字 符 的 像素 图 ， 这 点 前 面 已 经 讲 过 。 通 常 ， 它 是 只 读 存 储 器 (read-only memory )， 即 
ROM。 它 是 一 种 集成 电路 ， 在 生产 时 里 面 已 经 填 入 了 数据 ， 固 定 的 地 址 输出 的 数据 是 不 
变 的 。ROM 中 并 没有 数据 输入 信号 ， 这 点 与 RAM 不 同 。 


你 可 以 把 ROM 看 成 是 可 以 进行 代码 转换 的 电路 。 每 片 ROM 都 有 7 个 地 址 信号 (用 
来 表示 ASCII 码 ) 及 64 个 数据 输出 信号 , 里 面 存 储 了 128 个 ASCII 码 字符 的 8x8 像素 图 。 
因此 ，ROM 可 以 实现 7 位 ASCII 码 到 64 位 码 (定义 了 字符 显示 的 外 观 ) 的 转换 。 但 是 
你 有 没有 想 过 ，64 个 数据 输出 信号 会 使 蕊 片 变 得 很 大 。 更 合适 的 做 法 是 ， 用 10 个 地 址 信 
号 和 8 个 输出 信号 。 其 中 7 个 地 址 信号 是 用 来 确定 ASCII 码 字符 的 (这 7 个 地 址 位 来 自 
视频 板 上 RAM 的 数据 输出 ) 其 他 三 个 地 址 信号 则 用 来 表示 行 。 举 个 例子 来 说 ， 最 高 行 
用 000 表示 ， 最 低 行 用 111 表示 。8 个 输出 位 就 是 每 行 的 8 个 像素 。 


我 们 来 做 个 假设 ，ASCI 码 为 41h， 就 是 大 写 的 字母 A。 总 共有 8 行 , 每 行 8 位。 下 
表 给 出 了 字母 A 的 10 位 地 址 (ASCII 码 和 行 代码 之 间 用 空格 分 开 ) 和 数据 输出 信和 号。 


1080001 Q90 G0110000 
000001 O01 Of111000 
1000001 O18 11001100 
i00001 B11 11001100 


1900001 100 11111100 
i1000001 181 11081100 
1000004 110 T00100 
1000001 111 DOHC 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


从 上 表 中 ， 你 能 看 出 以 0 为 背景 、 用 1 表示 的 字母 A 吗 ? 


只 显示 文本 的 视频 显示 适配器 还 必须 支持 光标 〈 Cursor ) 功能 。 光 标 是 一 个 小 小 的 下 
画 线 ， 用 来 表明 从 键盘 上 输入 的 下 一 字符 会 在 屏幕 的 什么 位 置 显示 出 来 。 光 标 所 在 的 行 
和 列 常 被 存储 在 两 个 8 位 的 寄存 器 中 ， 这 两 个 寄存 器 也 是 视频 板 的 一 部 分 ， 而 且 微 处 理 
器 可 以 对 其 进行 写 操作 。 


有 的 显示 适配器 不 仅仅 只 显示 文本 ， 还 可 以 显示 其 他 数据 ， 我 们 称 这 样 的 显示 适 配 
器 为 图 形 适 配器 (图 形 显 卡 )。 通 过 向 图 形 显卡 上 的 RAM 写 入 数据 ， 微 处 理 器 就 可 以 画 
出 图 形 了 ， 当 然 能 显示 各 种 大 小 和 样式 的 文本 。 相 比较 而 言 ， 图 形 显 卡 要 比 只 显示 文本 
的 显卡 所 需 的 存储 空间 更 大 。320x200 的 图 形 显卡 有 64,000 个 像素 ,， 如果 每 个 像素 需要 1 
位 RAM, 那么 这 样 的 图 形 显卡 就 需要 64,000 位 的 RAM， 即 8000 字 节 。 然 而 ， 这 只 是 最 
低 的 要 求 。1 位 是 和 1 个 像素 相对 应 的 ， 只 能 用 来 表示 两 种 颜色 一 一 例如 黑白 两 色 。0 可 
能 对 应 于 黑色 像素 ，1 可 能 对 应 于 白色 像素 。 


让 我 们 仔细 观察 一 下 黑白 电视 机 ， 很 快 会 发 现 ， 它 们 不 仅仅 只 显示 黑色 和 白色 ， 还 
能 显示 不 同 灰 度 的 色彩 。 为 了 让 图 形 显卡 拥有 这 种 功能 , 通常 每 个 像素 对 应 于 RAM 中 的 
一 整个 字 节 ,其 中 00h 表示 的 是 黑色 ，FFh 表示 的 是 白色 , 介 于 两 者 之 间 的 数值 对 应 不 同 
的 灰 度 。 一 个 320x200 的 视频 板 若 能 显示 256 种 灰 度 ,就 需要 64,000 字 节 的 RAM。 这 与 
一 直 在 讨论 的 某 个 8 位 微 处 理 器 的 整个 地 址 空间 非常 接近 。 


如 果 想 显示 出 丰富 多 彩 的 颜色 ， 每 个 像素 就 需要 至 少 3 个 字 节 。 如 果 现 在 你 手头 有 
放大 镜 的 话 ， 不 妨 用 它 观察 一 下 彩色 电视 机 或 计算 机 视频 显示 器 ， 你 会 发 现 ， 每 种 颜色 
都 是 由 红 、 绿 、 蓝 三 原色 的 不 同 组 合 而 形成 的 。 为 了 获取 所 有 的 颜色 ， 三 原色 中 每 种 颜 
色 的 强度 都 需要 用 一 个 字 节 来 表示 。 这 人 么 算 来 ， 就 需要 192,000 字 节 的 RAM ( 更 多 有 关 
彩色 图 形 的 内 容 将 在 本 书 最 后 一 章 介绍 )。 


图 形 显卡 到 底 能 显示 出 多 少 种 不 同 的 颜色 呢 ? 这 与 每 个 像素 所 赋予 的 比特 数 是 有 关 
的 。 对 于 这 种 关系 ， 你 可 能 会 感到 很 熟悉 ， 因 为 本 书 中 讲 到 的 很 多 编码 都 与 之 类 似 ， 它 
们 都 涉及 2 的 医 ， 它 们 之 间 的 关系 如 下 : 


颜 色 数 量 =2 每 个 依 素 册 予 的 比特 数 


GE 


在 标准 的 电视 机 上 ,320x200 的 分 辩 率 是 所 能 达到 的 最 高 分 辩 率 。 正 是 由 于 这 样 的 原 
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21 总 线 了 = 


因 ， 我 们 要 为 计算 机 特制 显示 器 ， 以 使 其 具有 比 电 视 机 更 高 的 带宽 。1981 年 ， 第 一 台 显 
示 器 随 IBM PC 一 起 销售 ， 它 可 以 显示 25 行 ， 每 行 80 个 字符 。 这 正 是 使 用 在 IBM 大 型 
机 上 的 CRT 显示 器 能 显示 的 字符 数目 。 对 于 IBM 来 说 ，80 个 字符 具有 特殊 的 意义 ， 为 
什么 这 样 说 呢 ? 因 为 它 和 IBM 的 打 孔 卡片 ( punch card ) 上 的 字符 数目 一 样 。 的 确 ， 早 期 
连接 到 主机 上 的 CRT 显示 器 常 被 用 来 显示 打 孔 卡片 上 的 内 容 。 偶 尔 ， 你 会 听 到 有 人 称 只 
显示 字符 的 视频 显示 器 为 卡片 ， 当 然 这 是 一 种 过 时 的 叫 法 。 


这 么 多 年 以 来 ， 视 频 适 配器 的 分 辨 率 以 及 能 显示 的 颜色 不 断 增加 ， 这 两 者 也 成 为 了 
视频 显示 适配器 的 重要 参数 。 到 了 1987 年 ， 水 平 640 像素 、 垂 直 480 像素 的 视频 适配器 
被 IBM 的 PS/2 个 人 计算 机 和 苹果 公司 的 Macintosh HI 机 采用 ， 这 种 适配器 的 出 现 起 到 了 
里 程 碑 的 作用 ， 因 为 从 那 时 起 640x480 就 是 视频 分 辩 率 的 最 低 标 准 了 。 


640x480: 的 分 辩 率 具有 很 重要 的 意义 。 也 许 你 可 能 无 法 相信 ， 它 之 所 以 那么 重要 , 是 
因为 它 和 托马斯 爱迪生 (Thomas Edison，1847-1931 ) 有 关 。 大 概 在 1889 年 ， 爱 迪生 
及 他 的 工程 师 威 廉 * 肯尼迪 : 劳 里 . 迪克 生 ( William Kennedy Laurie Dickson ) 正在 进行 
活动 电影 摄影 机 和 活动 电影 放映 机 的 研究 ， 他 们 决定 ， 让 电影 图 像 的 宽 比 高 多 出 13。 图 
像 的 宽 和 高 之 比 ， 称 为 屏幕 长 宽 比 ( aspect ratio )。 通 常 ， 我 们 把 爱迪生 和 迪克 生 所 确定 
的 这 个 比 表示 成 1.33:1， 或 者 不 想 使 用 小 数 点 的 话 ， 就 表示 成 43。60 多 年 了 ， 大 多 数 电 
影 一 直 采 用 这 个 比例 ， 电 视 机 也 是 如 此 。 但 在 20 世纪 50 年 代 早 期 ， 好莱坞 引入 宽屏 
(widescreen ): 技 术 ， 与 电视 展开 竞争 ， 并 最 终 打破 了 这 个 比例 。 


多 数 计算 机 的 显示 器 的 长 宽 比 也 是 43， 如 果 你 不 信 的 话 ， 可 以 用 尺子 实际 量 一 下 ， 
就 可 以 证 明 我 所 说 非 虚 。640x480 分 辨 率 也 是 这 个 比例 。 这 就 说 明 〈 打 个 比方 ) 100 个 像 
素 的 水 平 线 和 100 个 像素 的 垂直 线 有 着 相同 的 物理 长 度 。 对 于 计算 机 图 形 学 来 说 ， 这 是 
个 非常 重要 的 特性 ， 我 们 称 为 正方 形 像素 ( square pixel )。 


如 今 ， 视 频 适 配器 和 显示 器 都 支持 640x480 的 分 辨 率 ， 但 同样 也 支持 多 种 其 他 的 视 
频 模 式 ， 包 括 800x600、1024x768、1280x960、1600x1200。 


我 们 常常 认为 计算 机 的 显示 器 和 键盘 之 间 存 在 某 种 联系 一 一 在 键盘 上 输入 什么 , 显示 
器 就 会 显示 什么 一 一 但 物理 上 它们 是 分 开 的 。 


其 实 键盘 上 的 每 个 按键 就 是 一 个 简单 的 开关 。 按 键 按 下 ， 开 关 就 会 闭合 。 现 在 个 人 
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下 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


计算 机 的 键盘 有 100 多 个 按键 ,但 类 似 于 打字 机 的 键盘 可 能 只 有 48 个 按键 。 


如 果 要 让 连接 到 计算 机 上 的 键盘 能 正常 工作 的 话 ， 就 需要 配备 一 些 硬件 来 为 每 个 按 
键 提供 唯一 的 代码 ， 以 便 区 分 哪 一 个 按键 被 按 下 了 。 假 定 这 个 代码 就 是 按键 的 ASCII 码 ， 
这 样 可 行 吗 ? 你 的 答案 或 许 是 肯定 的 ， 但 要 设计 出 能 识别 ASCI 码 的 硬件 却 是 不 切实 际 
的 。 举例 来 说 , 键盘 上 的 按键 A 对 应 的 ASCI 码 可 能 是 41h, 也 可 能 是 61h, 具体 是 哪个 ， 
还 取决 于 用 户 是 否 按 下 了 Shift 键 ; 另 外 ,现在 计算 机 键盘 上 有 很 多 的 按键 并 没有 ASCII 
码 与 之 对 应 。 我 们 称 键盘 硬件 提供 的 代码 为 扫描 码 ( scan code )。 当 按 下 键盘 上 的 某 个 按 
键 时 ,一 小 段 计算 机 程序 就 会 计算 出 这 个 按键 对 应 的 ASCII 码 ( 如 果 有 的 话 )。 


这 里 为 了 避免 键盘 硬件 的 电路 图 太 复杂 ， 假 设 键盘 上 只 有 16 个 按键 。 任 何 一 个 按键 
被 按 下 ， 键 盘 硬件 就 会 产生 一 个 4 位 的 代码 ， 二 进 制 数值 范围 是 0000 到 1111。 


键盘 硬件 包含 了 一 些 前 面 曾 讲 过 的 部 件 ， 如 下 图 所 示 。 


C 厂 4 位 计数 器 
Qo 人 QO, 


上 图 左下 部 分 所 示 的 是 键盘 的 16 个 按键 ,简单 地 用 开关 表示 。4 位 的 计数 器 在 按键 
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对 应 的 16 个 编码 间 快 速 是 重复 地 循环 着 ， 循 环 的 速度 必须 足够 快 ， 以 保证 在 按 下 并 松 开 
一 个 按键 之 前 循环 已 经 结束 。 


4 位 计数 器 的 输出 同样 也 是 2-4 译 码 器 和 4-1 数据 选择 器 的 输入 。 在 没有 按键 按 下 的 
情况 下 ， 选 择 器 的 输入 全 都 不 为 1， 因此， 其 输出 也 不 为 1; 一 旦 有 某 个 按键 被 按 下 ， 而 
且 与 4 位 计数 器 某 一 特定 输出 相对 应 ， 那 么 选择 器 的 输出 就 为 1。 例 如 ,如 果 右 上 角 对 角 
线 方向 的 第 二 个 开关 被 按 下 ， 且 计数 器 的 输出 是 0110， 选 择 器 就 会 输出 1， 如 下 图 所 示 。 


Qa Q: Qs 
, tp 
4 位 锁 存 和 
器  ， 


0110 就 是 这 个 按键 的 代码 。 在 这 个 按键 按 下 的 情况 下 ， 计 数 器 的 其 他 输出 都 不 会 使 选择 
器 的 输出 为 1， 也 就 是 说 每 个 按键 都 代码 都 是 唯一 的 。 


扫描 码 的 位 数 是 由 键盘 上 按键 的 数目 确定 的 。 如 果 键 盘 上 有 64 个 键 ， 就 需要 6 位 的 
扫描 码 ， 也 就 需要 一 个 6 位 的 计数 器 。 用 一 个 3-8 译 码 器 和 一 个 8-1 选择 器 就 可 以 把 这 些 
按键 组 成 一 个 8x8 的 阵列 。 如 果 键 盘 上 的 按键 数目 为 65 ~ 128 个 ， 就 需要 7 位 的 扫描 码 。 
你 就 可 以 用 一 个 4-16 译 码 器 和 一 个 8-1 的 选择 器 (或 者 一 个 3-8 译 码 器 和 一 个 16-1 选择 
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器 ) 把 这 些 按键 组 成 一 个 8x16 的 阵列 。 


在 这 个 电路 中 ， 接 下 来 将 会 发 生 什么 事情 呢 ? 这 取决 于 键盘 接口 。 每 个 按键 都 应 该 
在 RAM 中 拥有 1 位 的 存储 空间 ， 这 是 设计 键盘 硬件 时 该 考虑 的 事情 。 而 且 这 些 RAM 是 
由 计数 器 寻 址 的 ，RAM 的 内 容 为 0 或 1， 具 体 是 什么 值 取决 于 按键 按 下 (RAM 为 1) 与 
否 (RAM 为 0 )。 微 处 理 器 是 可 以 读 取 RAM 中 的 内 容 的 ， 并 通过 内 容 判 断 每 个 按键 的 状 
太 


To 


中 断 信号 是 键盘 接口 一 个 很 有 用 的 信号 。 回 想 一 下 前 面 讲 过 的 内 容 ， 我 们 知道 8080 
有 一 个 输入 信号 允许 外 部 设备 中 断 当 前 微 处 理 器 正 进行 的 工作 。 微 处 理 器 是 通过 从 内 存 
中 读 取 一 条 指令 来 响应 中 断 的 ， 通 常 是 一 条 RST 指令 。 这 条 指令 使 微 处 理 器 跳 转 到 内 存 
中 一 个 特定 的 区 域 并 执行 其 中 的 中 断 处 理 程序 。 


最 后 ,我 们 要 介绍 一 下 能 够 长 期 存储 信息 的 外 围 设备 。 前 面 曾 提 到 ， 无论 是 用 继 电 
器 、 电 子 管 ， 还 是 用 晶体 管 作为 介质 构成 随机 访问 存储 器 ,一 旦 掉 电 ， 它 存储 的 内 容 就 
会 丢失 。 正 因 如 此 ， 能 够 在 掉 电 时 长 期 保存 信息 的 存储 器 ， 是 一 台 完 整 的 计算 机 不 可 或 
缺 的 组 成 部 分 。 长 期 以 来 ， 大 们 通过 在 纸 上 或 卡片 上 打 孔 来 保存 永久 信息 ，IBM 打 孔 卡 
片 是 其 中 典型 的 代表 。 在 早期 小 型 计算 机 中 ， 为 了 能 够 长 久保 存 程序 和 数据 ， 通 常 在 滚 
动 的 纸 带 上 打 孔 ， 而 在 需要 时 ， 这 些 程序 和 数据 可 以 从 纸 带 加 载 到 内 存 。 


打 孔 卡片 和 纸 带 的 使 用 也 不 是 尽善尽美 的 ， 它 也 存在 一 些 问题 。 首 先是 介质 的 不 可 
重用 性 ,一 旦 打 孔 卡片 或 纸 带 被 打 孔 后 就 很 难 还 原 为 原来 的 状态 。 其 次 是 效率 很 低 ， 假 
如 你 有 机 会 看 到 当时 纸 带 上 保留 的 某 一 比特 信息 ， 就 会 发 现 这 种 做 法 实在 太 浪费 纸 带 了 。 


正 是 由 于 这 些 原因 , 打 孔 卡片 和 纸 带 慢 慢 退出 了 历史 的 舞台 。 磁 介质 存储 器 ( magnetic 
storage ) 逐渐 发 展 成 目前 最 为 流行 的 长 期 存储 器 。 磁 介质 存储 器 的 起 源 要 追 滴 到 1878 年 ， 
这 一 年 美国 工程 师 奥 柏林 . 史密斯 (Oberlin Smith，1840-1926 ) 描述 了 它 的 工作 原理 。 
1898 年 ， 即 工作 原理 被 提出 20 年 后 , 第 一 块 可 用 的 磁 介质 存储 器 问世 ,， 它 由 丹麦 发 明 家 
巴尔 德 马 尔 : 波 尔 森 ( Valdemar Poulsen，1869-1942 ) 制造 。 波 尔 森 后 来 发 明了 录音 电话 
机 ， 当 家 里 没 人 时 ， 通 过 它 可 以 记录 收 到 的 电话 信息 。 声 音 通过 电磁 铁 和 可 变 长 度 的 金 
属 丝 来 记录 ， 其 中 电磁 铁 是 电报 机 里 很 常见 的 部 件 ， 它 根据 声音 的 高 低 来 磁化 金属 丝 。 
当 磁 化 的 金属 丝 切割 电磁 线圈 运动 的 时 候 ， 产 生 的 电流 强度 与 其 磁化 程度 有 关 。 不 论 使 
用 何 种 磁化 介质 ， 记 录 和 读 取 信息 都 是 利用 电磁 铁 的 磁头 (head ) 来 完成 的 。 
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1928 年 ， 澳大利亚 发 明 家 弗 里 泌 : 佛 勒 玛 (Fritz Phleumer ) 发 明了 一 种 磁 记 录 设 备 ， 
并 为 其 申请 了 专利 。 此 设备 采用 在 生产 香烟 上 的 金属 带 时 所 用 的 技术 ， 将 铁 粒 子 履 盖 在 
很 长 的 纸 带 上 。 不 久 以 后 ， 纸 带 被 强度 更 高 的 醋酸 盐 纤 维 素 取代 ， 而 一 种 更 耐 入 、 更 知 
名 的 记录 介质 也 从 此 诞生 一 一 卷轴 式 磁 带 ， 它 被 包装 在 塑料 盒 里 ， 可 以 很 方便 地 使 用 。 对 
于 记录 和 回放 音乐 及 视频 来 说 ， 卷 轴 式 磁带 无 疑 是 很 受 欢迎 的 介质 。 


1950 年 ， 雷 明 顿 兰 德 公司 (Remington Rand ) 发 明了 第 一 个 用 于 记录 计算 机 数字 数 
据 的 商用 磁带 系统 。 当 时 ， 磁 带 的 容量 有 限 ， 一 个 0.5 英寸 的 卷轴 式 磁 带 容量 只 有 几 兆 字 
节 。 在 早期 家 用 计算 机 中 ， 常 见 的 盒 式 磁带 录音 机 被 人 们 用 来 保存 信息 。 通 过 调用 一 些 
小 的 程序 ， 可 以 将 内 存 块 中 的 内 容 保存 到 磁带 上 ， 以 后 再 需要 时 还 可 以 从 磁带 调 入 内 存 
中 。 在 第 一 代 IBM PC 上 ， 有 一 个 专 为 连接 盒 式 磁 带 存 储 器 而 设计 的 接头 。 至 今 ， 磁 带 仍 
然 是 一 种 很 通用 的 存储 介质 ， 对 于 那些 想 要 长 期 保存 的 文档 ， 磁 带 更 是 首要 的 选择 。 但 
是 ， 磁 盘 并 不 是 最 理想 的 存储 介质 ， 想 要 快速 地 移动 到 磁盘 的 任 一 位 置 是 不 可 能 的 ， 它 
只 能 顺序 访问 ， 频 繁 地 快 进 和 倒 带 会 花费 很 多 时 间 。 


以 几何 学 角度 来 看 ， 磁 盘 是 能 够 实现 快速 访问 的 介质 。 磁 盘 围 绕 其 中 心 旋 转 ， 连 到 
璧 上 的 一 个 或 多 个 磁头 从 磁盘 外 沿 向 中 间 移 动 ， 通 过 磁头 可 以 快速 访问 磁盘 上 的 任何 区 
域 。 


在 记录 声音 信息 方面 ， 磁 盘 实 际 上 要 早 于 磁带 。 早 在 1956 年 ，IBM 公司 就 发 明了 世 
界 上 首 款 用 来 存储 计算 机 数据 的 磁盘 驱动 器 ， 称 为 RAMAC (Random Access Method of 
Accounting and Control， 计 算 与 控制 过 程 中 的 随机 访问 模式 )， 它 由 50 个 金属 盘 片 组 成 ， 
直径 2 英尺 ， 存 储量 为 5 MB。 


自从 磁盘 被 用 作 记 录 信 息 以 来 ， 它 的 体积 越 来 越 小 而 容量 越 来 越 大 ， 习 惯 上 将 磁盘 
分 为 软盘 (floppy disk ) 和 硬盘 ( hard disk, 或 fixed disk )。 软 盘 是 由 单 面 覆盖 磁性 物质 的 
塑料 片 组 成 ， 外 面 由 厚 纸板 或 塑料 包装 ， 起 到 保护 作用 (塑料 包装 主要 是 防止 磁盘 弯 折 ， 
虽然 现在 的 磁盘 看 起 来 不 像 以 前 的 软盘 那么 松软 ， 而 且 还 有 很 多 的 区 别 ， 但 软盘 这 个 名 
字 一 直 在 用 ， 延 续 至 今 ) 在 使 用 软盘 的 时 候 ， 必 须 将 其 播 入 到 软盘 驱动 器 ， 软 盘 驱 动 器 
是 一 个 连接 到 计算 机 的 部 件 ,， 通 过 它 可 以 读 / 写 磁 盘 中 的 内 容 。 早 期 的 软盘 直径 为 8 英寸 ， 
第 一 代 IBM PC 使 用 的 是 5.25 英寸 的 软盘 , 不 过 , 现在 最 流行 的 是 3.5 英寸 的 软盘 。 软 盘 
有 很 大 的 灵活 性 ， 可 以 实现 在 不 同 计 算 机 之 间 传 递 数 据 。 对 商用 软件 来 说 ， 磁 盘 仍 然 是 
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一 个 不 可 或 缺 的 发 行 媒介 。 


硬盘 是 由 多 个 金属 磁盘 构成 的 ， 它 永久 驻 留 在 驱动 器 里 。 相 对 于 软盘 来 说 ， 它 的 存 
取 速 度 更 快 、 存 储量 更 大 ， 唯 一 的 缺点 是 硬盘 本 身 是 固定 的 ， 不 能 移动 。 


磁盘 的 表面 被 划分 成 许多 同心 圆 ， 称 为 磁道 ( tracks ), 每 个 磁道 又 被 划分 成 像 圆 饼 切 
片 形状 的 扇 区 〈 sectors )， 每 个 扇 区 可 以 存放 一 定数 量 的 字 节 ， 通 常 为 512 字 节 。 第 一 代 
IBM PC 上 使 用 的 软盘 只 有 一 面 可 以 存储 信息 ， 直 径 5.25 英寸 ， 被 划分 成 40 个 磁道 ， 每 
个 磁道 8 个 扇 区 ， 每 个 肩 区 存储 512 字 节 数据 。 通 过 计算 , 每 个 软盘 可 以 存储 163,840 字 
节 数 据 ， 即 160 KB。 现今 PC 兼容 机 使 用 的 软盘 通常 有 两 面 ， 每 面 80 个 磁道 ， 每 个 磁道 
18 个 扇 区 ， 每 个 扇 区 512 字 节 ， 总 的 磁盘 容量 是 1,474,560 字 节 ， 即 1440 KB。 


1983 年 ,IBM 在 其 PC/XT 上 率先 使 用 了 硬盘 驱动 器 ,当时 硬盘 的 容量 仅仅 只 有 10 MB。 
自 此 之 后 的 16 年 里 , 硬盘 的 容量 扩大 了 上 百倍 , 而 价格 一 直 在 下 降 。1999 年 , 20 GB( 200 
亿 字 节 ) 容量 的 硬盘 驱动 器 诞生 了 ， 而 售 价 却 不 到 400 美元 。 


软盘 和 硬盘 通常 有 它们 自己 的 电气 接口 ， 除 此 之 外 ， 为 了 能 和 微 处 理 器 交互 数据 ， 
这 些 电气 接口 与 微 处 理 器 之 间 还 需要 有 额外 的 接口 与 之 相连 。 现 在 流行 的 硬盘 驱动 器 标 
准 接口 有 : 小 型 计算 机 系统 接口 ( Small Computer System Interface，SCSI ); 增强 的 小 型 
设备 接口 ( Enhanced Small Device Interface, ESDI ) 和 集成 设备 电气 接口 ( Integrated Device 
Electronics，IDE )。 这 些 接口 都 利用 直接 内 存 访 问 ( direct memory access，DMA ) 技术 来 
使 用 总 线 , DMA 可 以 不 经 过 微 处 理 器 , 实现 数据 在 随机 访问 存储 器 和 硬盘 之 问 直接 传送 。 
这 样 的 传送 是 以 块 为 单位 进行 的 ， 每 次 传输 的 块 大 小 是 磁盘 扇 区 字 节 数 的 倍数 ， 通 常 是 
512 字 节 。 


由 于 经 常 听 到 关于 兆 字 节 和 吉 字 节 之 类 的 相关 术语 方面 的 谈论 ， 让 很 多 家 用 计算 机 
的 初学 者 感到 困惑 ， 到 底 随 机 访问 存储 器 和 磁盘 存储 器 有 什么 区 别 ? 不 过 最 近 儿 年 推出 
了 一 条 分 类 规则 ， 这 让 人 们 对 术语 的 困惑 减少 了 许多 。 这 条 规则 规定 : memory (内存 ) 
仅仅 表示 半导体 随机 访问 存储 器 ; storage ( 存储 器 ) 用 来 指 任何 的 存储 设备 ,通常 包括 软 
盘 、 硬 盘 和 磁带 。 在 本 书 中 ， 尽 量 遵循 这 些 规 则 ， 它 的 确 能 够 给 我 们 带 来 许多 好 处 。 


实际 上 ， 存 储 的 信息 是 否 易 失 ， 是 随机 访问 存储 器 与 磁 介 质 存 储 器 的 主要 区 别 。 随 
机 访问 存储 器 是 易 失 性 存储 设备 ， 一 旦 掉 电 ， 存 储 内 容 将 会 消失 ; 而 磁 介 质 存 储 器 是 永 
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入 性 存储 设备 ， 像 软盘 和 磁盘 ， 除 非 故 意 删 除 或 写 覆 盖 ， 否 则 数据 将 会 一 直 保留 不 变 。 
如 果 对 微 处 理 器 的 工作 原理 很 了 解 ， 就 会 观察 到 随机 访问 存储 器 和 磁 介 质 存 储 器 之 间 的 
显著 区 别 ， 例 如 当 微 处 理 器 发 出 一 个 地 址 信号 ， 通 常 是 寻 址 随机 访问 存储 器 ， 而 非 磁 介 
质 存 储 器 。 


微 处 理 器 不 能 直接 从 磁盘 读 取 数据 ， 需要 将 所 需 的 数据 从 磁盘 调 入 内 存 〔 随机 访问 
存储 器 )， 然 后 它 才 能 对 其 访问 ， 当 然 这 需要 额外 的 步骤 。 微 处 理 器 还 需要 执行 一 段 小 程 
序 ， 这 段 程序 会 访问 磁盘 ， 并 将 数据 从 磁盘 调 入 内 存 。: 


关于 随机 访问 存储 器 和 磁 介 质 存储 器 之 间 的 差别 ， 有 个 形象 的 比喻 可 以 帮助 我 们 加 
深 理解 : 随机 访问 存储 器 就 像 办 公 桌 的 桌面 ， 上 面 的 任何 东西 都 可 以 拿 来 直接 使 用 ;而 
磁 介 质 存储 器 就 像 一 个 文件 柜 ， 里 面 的 东西 不 能 直接 使 用 ， 如 果 想 要 使 用 放 在 文件 柜 里 
的 某 件 东西 ， 你 需要 站 起 来 ， 走 到 文件 柜 前 ， 查 找 需 要 的 文件 ， 然 后 带 回 桌面 。 如 果 桌 
面 太 拥 挤 ， 没 有 空间 放置 需要 的 文件 ， 还 需要 把 桌面 上 暂时 不 用 的 东西 先 放 回 到 文件 柜 
中 。 


这 个 比喻 恰到好处 ,实际 上 ， 存 储 在 磁盘 上 的 数据 的 确 是 以 文件 ( files ) 作为 实体 来 
存放 的 。 存 储 和 检索 文件 是 操作 系统 ( Operating System ) 很 重要 的 一 个 功能 ， 关 于 操作 
系统 的 相关 知识 ， 下 一 章 将 会 进行 专门 介绍 。 
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操作 系统 


一 直 以 来 , 有 一 种 想法 在 我 们 脑子 里 涌 动 : 亲手 去 组 装 一 -在 想象 中 进行 虚拟 组 装 也 
台 近 似 完整 的 计算 机 。 一 块 微 处 理 器 、 一 些 随机 访问 存储 器 、 一 款 键盘 、 一 台 


可 以 
视频 显示 器 和 一 个 磁盘 驱动 器 是 这 台 计 算 机 所 拥有 的 部 件 。 当 所 有 的 硬件 各 就 各 位 ， 我 
们 激动 地 杂 着 计算 机 的 开关 ， 伸 出 手 来 给 它 上 电 ， 将 这 台 计 算 机 从 沉睡 中 唤醒 。 或 许 上 
面 描述 的 这 一 切 会 在 你 的 脑海 中 产生 一 副 维 克 多 “' 弗 兰 肯 斯 坦 ! (Victor Frankenstein ) 组 
装 怪物 时 的 场景 ， 甚 至 你 或 许 还 会 想起 老 木 偶 匠 盖 比 特 ( Geppetto ) 正在 雕刻 木偶 匹 诺 曹 
(Pinocchio ) 的 情形 。 


但 我 们 还 是 凋 了 一 些 东 西 ， 既 不 是 雷霆 万 钩 的 威力 ， 也 不 是 对 着 流星 许 下 的 纯洁 愿 
望 。 让 我 们 继续 投入 到 工作 中 : 运行 这 台新 组 装 的 计算 机 ， 请 告诉 我 你 眼前 出 现 了 什么 ? 
当 阴 极 射线 管 加 热 之 后 ,一 溃 排 列 整齐 一 一 而 义 完 全 随机 的 一 一 ASCI 码 字 符 阵列 出 
现在 屏幕 上 。 不 出 我 们 所 料 ， 掉 电 的 时 候 ， 半 导体 存储 器 中 的 内 容 就 会 被 全 部 清 零 ， 而 


1 “ 弗 兰 表 斯 坦 ” 是 英国 车 名 小 说 家 玛丽 * 雪 莱 (Mary Shelley ) 创作 的 同名 小 说 中 一 个 疯狂 
科学 家 的 名 字 。 小 说 中 ， 弗 兰 肯 斯 坦 用 许多 碎 厂 块 拼接 成 一 个 “和 人 ”， 并 用 内 电 将 其 激活 。 
玛丽 * 雪 莱 是 英国 著名 浪漫 主义 诗人 雪 莱 的 妻子， 被 誉 为 科幻 小 说 之 母 。 
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首次 给 它 上 电 的 时 候 ， 它 将 处 于 随机 月 不 可 预测 的 状态 。 同 样 ， 我 们 用 来 构建 微 处 理 器 
的 所 有 RAM 都 包含 随机 的 字 节 。 如果 可 能 , 开机 后 微 处 理 器 会 将 这 些 随 机 字 节 解释 为 机 
器 代码 并 执行 。 不 用 担心 会 因此 发 生 什么 糟糕 的 事情 一 一 计算 机 不 会 因此 而 坏 掉 一 一 但 
是 ， 计 算 机 也 无 法 完成 任何 有 意义 的 工作 。 

这 里 我 们 漏 掉 的 就 是 软件 。 当 一 个 微 处 理 器 首次 上 电 或 复位 时 ， 它 会 从 特定 的 内 存 
地 址 开始 执行 机 器 代码 。 在 英特尔 的 8080 系统 中 ， 这 个 地 址 就 是 0000h。 在 一 台 设 计 精 
良 的 计算 机 中 ， 通 过 上 电 启 动 ， 将 会 有 一 条 机 器 代码 指令 被 载 入 到 该 内 存 地 址 中 (一 般 
情况 下 是 一 段 程序 的 第 一 条 指令 )。 


机 器 代码 指令 是 怎么 加 载 到 那个 内 存 地 址 中 的 昵 ?把 软件 安装 到 一 台新 设计 的 计算 
机 的 过 程 ， 可 能 是 整个 过 程 中 最 令 人 困惑 的 部 分 了 ， 怎 样 理解 它 呢 ?让 我 们 先 从 第 16 章 
所 讲 的 一 个 控制 面板 入 手 吧 ， 这 个 控制 面板 的 功能 是 把 字 节 写 入 随机 访问 存储 器 ， 之 后 
还 可 将 其 读 出 。 
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与 前 面 介绍 过 的 有 所 不 同 ， 这 个 控制 面板 上 设计 了 一 个 复位 开关 。 复 位 开关 与 微 处 
理 器 的 复位 输入 相连 接 。 一 旦 复位 开关 闭合 ( 置 1 )， 微 处 理 器 就 会 停止 工作 ; 当 此 开关 
断 开 后 ( 置 0)， 微 处 理 器 就 开始 执行 机 器 代码 。 


使 用 此 控制 面板 的 方法 是 : 打开 复位 开关 ， 微 处 理 器 复位 并 停止 执行 机 器 代码 ; 打 
开 控 制 开 关 , 就 会 接收 总 线 上 的 地 址 信号 和 数据 信号 。 在 该 状态 下 , 你 可 以 通过 开关 Ao ~ 
Ai 来 指定 一 个 16 位 的 存储 器 地 址 ; 通过 灯泡 De ~ D7 的 明 灭 组 合 来 显示 该 存储 器 地 址 
中 的 8 位 数据 。 那 么 怎样 把 一 个 新 的 字 节 写 入 到 此 地 址 中 呢 ? 首先 通过 开关 Do ~ D7 来 
设置 想 要 写 入 的 字 节 ， 然 后 把 写 入 开关 先 打 开 再 关闭 。 当 你 已 经 完成 向 存储 器 中 播 入 字 
节 的 工作 后 ， 关 上 控制 及 复位 开关 ， 微 处 理 器 就 会 执行 程序 。 


上 面 这 个 过 程 展示 了 向 这 台 我 们 刚刚 打造 出 来 的 计算 机 输入 第 一 条 机 器 代码 的 步骤 。 
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不 言 而 喻 ， 这 是 一 个 耗 时 耗 力 的 过 程 。 在 这 个 过 程 中 一 些小 错误 是 在 所 难免 的 。 看 看 你 的 
手指 ， 或 许 已 经 磨 出 了 水 泡 ， 你 的 大 脑 也 感觉 一 片 混 乱 ， 而 这 一 切 都 是 工作 的 代价 。 


但 当 你 开始 用 视频 显示 器 显示 程序 运行 的 结果 时 ， 到 底 是 什么 使 这 一 切 都 变 得 简单 、 
方便 呢 ? 上 一 章 中 我 们 讲 到 只 显示 字符 的 视频 显示 器 , 它 有 一 个 1 KB 的 随机 访问 存储 器 ， 
可 以 存储 25 行 、 每 行 40 个 字符 的 ASCII 码 。 程 序 将 要 显示 的 内 容 写 入 到 此 存储 器 中 ， 
其 方法 与 向 计算 机 中 其 他 存储 器 中 写 入 数据 的 方法 一 样 。 


尽管 把 程序 的 输出 结果 显示 在 视频 显示 器 上 看 似 简单 ， 实 则 不 然 。 例 如 ， 你 编写 了 
一 个 程序 用 来 完成 某 个 计算 任务 , 如 果 计 算 结 果 是 4Bh, 不 能 将 这 个 值 直接 写 入 到 视频 显 
示 器 的 内 存 中 。 如 果 犯 了 这 样 的 错误 , 屏幕 上 显示 的 将 是 字母 及 , 因为 此 字母 的 对 应 ASCII 
码 的 值 正 是 4Bh。4Bh 由 两 个 字符 组 成 , 其 中 4 对 应 的 ASCII 码 是 34h，B 对 应 的 ASCII 
码 是 42h, 应 该 将 这 两 个 ASCII 码 写 到 视频 显示 器 存储 器 上 , 才能 在 显示 器 上 看 到 期 望 的 
数值 。 这 里 再 强调 一 下 ，8 位 二 进 制 数 可 以 表示 两 位 十 六 进 制 数字 ， 因 此 必须 将 每 一 位 十 
六 进 制 数字 对 应 的 ASCII 码 ， 写 入 到 视频 显示 器 的 存储 器 中 才能 显示 这 个 数 。 


这 种 转换 可 以 通过 编写 小 的 程序 来 实现 。 下 面 是 一 段 8080 汇编 程序 , 功能 是 把 存储 在 累 
加 器 中 的 十 六 进 制 数 〈 假设 这 个 数 介 于 00h 与 0Fh 之 间 ) 的 每 一 位 转换 成 对 应 的 ASCII 码 : 


NibbleToAscii: CPI A，0Ah ;检查 是 数字 还 是 字母 


JC Number 
ADD A，37h ; 把 A~F 转换 成 41h~46h 
RET 
Number : ADD A，30h ; 把 数字 0~9 转换 成 30h~39h 
RET 


通过 两 次 调用 NibbleToAscii， 下 面 的 程序 实现 了 把 累加 器 A 中 的 一 个 字 节 转换 成 两 个 
ASCII 码 对 应 的 数字 ,分 别 存放 在 寄存 器 B 和 C 中。 


ByteToAscii: PUSH PSW ; 保存 累加 器 A 
RRC 
RRC 
RRC 
RRC ; 获取 高 半 字 节 
CALT NibbleToAscii ; 转换 成 ASCII 码 
MOV B, A ; 把 结果 存 入 寄存 器 B 中 
POP PSW ; 取出 原始 的 A 
AND A, OFh ; 获取 低 半 字 节 


CALL NibbleToAscii ; 转换 成 ASCII 码 
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MOV C, A ; 把 结果 存 入 寄存 器 c 中 
RET 


通过 这 些 程序 ， 可 以 把 一 个 用 十 六 进 制 表示 的 字 节 显示 在 视频 显示 器 上 。 进 一 步 来 讲 ， 
如 果 想 把 它 转换 成 十 进 制 数 ， 还 需要 做 些 别 的 工作 。 这 个 过 程 与 把 一 个 数 从 十 六 进 制 转 
换 成 十 进 制 的 过 程 ( 用 10 除 几 次 ) 十 分 相似 。 


记 住 ， 到 此 为 止 实际 上 你 还 没有 将 汇编 语言 程序 写 入 到 内 存 。 你 需要 把 汇编 语言 写 
到 纸 上 ， 将 它们 转换 成 机 器 代码 后 才 写 入 到 内 存 中 。 直 到 第 24 章 我 们 一 直 都 会 采用 这 种 
“手工 汇编 ”的 方式 。 


控制 面板 的 确 不 需要 很 多 硬件 支持 ， 但 它 不 便于 使 用 ， 因 为 它 有 着 最 糟糕 的 输入 / 输 
出 形式 。 我 们 甚至 可 以 从 头 开始 独立 建造 一 台 计 算 机 ， 但 仍然 无 法 改变 这 样 糟糕 的 输入 / 
输出 方式 一 一 通过 按键 输入 0 和 ! 一 一 这 的 确 让 人 篮 丛 。 如 何 把 控制 面板 去 掉 是 要 解决 的 
首要 问题 。 


实现 按键 来 控制 输入 /输出 的 不 二 之 选 就 是 键盘 。 前 面 我 们 已 经 搭建 了 一 个 计算 机 键 
盘 ， 每 次 有 按键 按 下 的 时 候 ， 就 会 产生 一 个 中 断 信 号 送 至 微 处 理 器 。 计 算 机 内 有 中 断 控 
制 芯片 ， 通 过 执行 一 条 RST 指令 使 得 微 处 理 器 响应 这 次 中 断 ， 例 如 RST 1， 微 处 理 器 执 
行 这 条 指令 ,把 当前 程序 计数 器 的 值 压 入 到 堆栈 中 ,然后 跳 转 到 地 址 0008h 处 。 可 以 直 
接 在 这 片 地 址 空间 上 输入 一 些 代 码 ( 使 用 控制 面板 )， 这 些 代 码 称 为 键盘 处 理 程序 
( keyboard handler )。 


为 了 使 复位 后 微 处 理 器 能 正常 工作 ， 微 处 理 器 在 复位 的 时 修 需 要 执行 一 些 代码 ， 称 
为 初始 化 代码 ( initialization code )。 堆栈 指 针 在 运行 初始 化 代码 的 [ 才 候 会 被 设置 ， 以 保证 
堆栈 处 在 内 存 的 有 效 区 域内 。 为 了 不 让 屏幕 上 显示 随机 字符 ， 初 始 化 代码 还 把 视频 显示 
器 内 存 中 的 每 个 字 节 设置 成 十 六 进 制 数 20h, 在 ASCI 码 中 这 是 一 个 空格 符 。 此 外 ,初始 
化 代码 还 要 把 光标 定位 在 第 一 行 第 一 列 的 位 置 -一 OUT(Output ) 指 令 可 以 完成 这 一 操作 : 
光标 在 视频 显示 器 上 是 以 下 画 线 的 形式 出 现 的 一 一 它 可 以 显示 出 下 一 个 要 输入 字符 的 位 
置 。 为 了 使 微 处 理 器 能 响应 键盘 中 断 ， 必 须 设 置 EI 指令 开 中 断 ， 而 HLT 指令 可 以 使 微 处 
理 器 停止 工作 。 


上 面 讲述 的 就 是 初始 化 代码 的 作用 。 执 行 了 HLT 指令 后 ， 计 算 机 则 处 于 停机 状态 。 为 
了 把 计算 机 从 停机 状态 唤醒 ， 只 能 通过 控制 面板 的 复位 信号 或 者 键盘 的 中 断 信号 来 实现 。 
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键盘 处 理 程序 的 规模 要 远大 于 初始 化 代码 , 这 个 程序 才 是 真正 响应 键盘 事件 的 代码 段 。 


任何 时 候 ， 只 要 键盘 上 的 一 个 按键 被 按 下 ， 微 处 理 器 就 会 响应 本 次 中 断 ， 并 从 初始 化 
代码 末尾 的 HLT 语句 跳 转 到 键盘 处 理 程序 。 键 盘 处 理 程序 利用 IN (Input ) 指令 用 来 检查 是 
哪个 按键 被 按 下 ， 并 根据 这 个 按键 执行 相关 的 操作 (就 是 说 ， 键 盘 处 理 程序 对 每 个 按键 进 
行 相 应 的 处 理 )， 然 后 执行 RET (Retum ) 指令 以 返回 HLT 语句 ， 等 待 另 一 个 键盘 中 断 。 


当 你 按 下 字母 、 数 字 或 者 是 标点 符号 键 的 时 候 ， 键 盘 扫 描 程 序 就 会 启用 键盘 扫描 码 ， 
并 根据 Shift 键 是 按 下 与 否 确 定 相应 的 ASCII 码 。 接 下 来 我 们 要 做 的 ,就 是 要 把 这 个 ASCI 
三 写 到 视频 显示 器 的 内 存 中 ， 当 然 这 不 是 随意 的 ， 而 是 要 号 在 光标 所 在 的 位 置 。 这 样 的 
一 个 过 程 ， 我 们 可 以 很 形象 地 称 之 为 按键 到 显示 器 的 回 显 (echoing )。 光 标 会 随 着 字符 的 
写 入 而 移动 ,换言之 ， 它 总 会 出 现在 刚 显示 的 字符 后 面 的 空格 处 。 通 过 键盘 ， 可 以 输入 
一 串 字 符 ， 然 后 把 它们 在 屏幕 上 显示 出 来 。 


当 按 下 回 退 键 《相应 的 ASCII 码 值 是 08h ) 时 ， 最 后 写 入 视频 显示 器 内 存 中 的 字符 会 
被 键盘 处 理 程序 删除 (其实 并 不 复杂 一 一 我 们 只 要 把 空格 符 对 应 的 ASCI 码 一 20h 写 入 
到 那个 内 存 位 置 处 就 行 了 )。 在 这 个 过 程 中 ， 光 标 会 移 回 一 格 。 


通常 我 们 在 输入 一 行 字符 时 ， 错 误 是 难免 的 ， 这 时 就 需要 用 退 格 键 来 改正 错误 ， 然 
后 按 下 回 车 键 。 回 车 键 并 不 难 找到 ， 键 盘 上 标 有 “Enter” 字 样 的 按键 就 是 。 打 字 员 在 电 
动 打 字 机 上 按 下 “Returm” 键 表示 已 经 完成 一 行文 字 的 输入 ,同时 也 表明 他 们 已 经 做 好 了 
输入 下 一 行 的 准备 ， 光 标 会 指向 下 一 行 的 开始 。 同 样 ， 在 计算 机 中 “Enter” 键 用 来 实现 
相同 的 功能 ， 结 束 一 行 的 输入 并 转 到 下 一 行 。 


当 键 盘 处 理 程序 对 “Return” 或 “Enter” 键 (对 应 的 ASCI 码 是 0Dh ) 进行 处 理 时 ， 
它 把 视频 显示 器 内 存 中 的 这 一 行文 本 解释 为 计算 机 的 一 条 命令 ( command )， 换 言 之 ， 键 
盘 处 理 程序 的 任务 是 执行 此 命令 。 实 际 上 ， 在 键盘 处 理 程序 内 含有 一 个 命令 处 理 程序 
( command processor )， 它 可 以 解释 如 下 三 条 命令 : W 命令 、 DD 命令 和 RR 命令 。 下 面 我 们 
来 深入 地 理解 一 下 它们 。 

首先 是 W 命令 。 它 是 以 W 开头 的 文本 行 ， 此 命令 用 来 把 若干 字 节 写 入 ( Write ) 到 
内 存 中 。 例 如 输入 到 屏幕 上 的 一 行内 容 如 下 所 示 : 


W 1020 35 4F 78 23 9B AC 67 
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运行 这 条 命令 ,命令 处 理 程序 会 从 内 存 地 址 1020h 处 开始 ， 把 35、4Ff 等 十 六 进 制 表 示 的 
字 节 写 入 内 存 中 。 要 完成 这 项 工作 , 键盘 处 理 程序 需要 把 ASCII 码 转 换 成 字 节 一 一 前 面 讲 
过 把 字 节 转换 成 ASCII 码 ， 这 里 其 实 就 是 它 的 道 变换 。 


接 下 来 是 D 命令 。 它 是 以 D 开头 的 文本 行 ， 此 命令 用 来 把 内 存 中 的 一 些 字 节 显 示 
(Display ) 出 来 。 例 如 输入 到 屏幕 上 的 一 行内 容 如 下 所 示 : 


D 1030 


接收 到 命令 后 ,命令 处 理 程序 会 把 从 地 址 1030h 开始 的 11 个 字 节 的 内 容 显示 出 来 ( 这 
里 之 所 以 说 是 11 个 字 节 , 是 因为 在 一 个 每 行 可 以 容纳 40 个 字符 的 显示 器 上 , 除去 显示 命 
令 与 地 址 标识 ， 后 面 能 显示 的 也 只 有 这 人 么 多 了 )。 有 了 这 条 命令 ， 就 可 以 很 方便 地 查看 内 
存 中 的 内 容 了 。 


最 后 是 R 命令 。 它 是 以 及 开头 的 文本 行 ， 表 示 运 行 (Run )。 该 命令 的 形式 如 下 : 


R 1000 


执行 此 命令 意味 着 “处 理 器 会 运行 从 地 址 1000h 开始 的 一 段 程序 ”。 首 先 命令 处 理 
程序 把 1000h 存储 在 寄存 器 对 HL 中 ， 接 着 执行 指令 PCHL， 这 条 指令 的 功能 是 , 把 HL 
所 存储 的 值 加 载 到 程序 计数 器 中 ， 然 后 跳 转 到 程序 计数 器 指向 的 地 址 并 运行 程序 。 


键盘 处 理 程序 及 命令 处 理 程序 简化 了 很 多 工作 ， 可 以 说 是 计算 机 发 展 的 一 个 里 程 碑 。 
且 使 用 了 和 它 ， 就 无 须 理会 那个 令 人 难以 忍受 的 控制 面板 了 。 我 们 不 得 不 承认 ， 使 用 键 
盘 输入 更 简单 、 更 快 、 更 好 ， 这 是 其 他 方法 无 法 媲美 的 。 


但 是 ， 你 仍然 没有 摆脱 之 前 的 老 问 题 ， 一 旦 关 掉 电源 ， 你 辛 辛 苦 苦 所 输入 的 数据 会 
全 部 消 失 。 当 然 ， 你 可 以 把 所 有 新 代码 存 到 只 读 存储 器 (ROM ) 中 。 还 记得 上 一 章 中 ， 
我 们 讲 到 的 那个 ROM 芯片 吗 ? 它 就 包含 了 把 ASCI 码 字 符 显示 到 视频 显示 器 上 所 需 的 全 
部 点 阵 模 式 。 这 里 假定 , 这 些 数据 在 厂家 制造 芯片 时 已 经 配置 好 了 , 当然 你 也 可 以 对 ROM 
芯片 进行 编程 。 可 编程 只 读 存储 器 (Programmable Read-Only Memory，PROM ) 只 能 编 
程 一 次 ;而 可 擦 除 可 编程 只 读 存储 器 ( Erasable Programmable Read-Only Memory, EPROM ) 
可 重复 擦 除 和 写 入 ， 该 芯片 的 正面 开 有 一 个 玻璃 窗口 ， 让 紫外 线 透 过 这 个 筷 照 射 内 部 芯 
片 就 可 以 擦 除 其 中 的 内 容 了 。 


回忆 前 面 曾 讲 过 的 内 容 ， 你 一 定 会 想起 ，RAM 板 与 一 个 DIP 开关 相连 ， 有 了 这 个 开 
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关 就 可 以 设 定 RAM 板 的 起 始 地 址 了 。8080 系统 在 初始 化 时 , 其 中 一 个 RAM 板 的 起 始 地 
址 被 设置 为 0000h。 但 是 如 果 有 ROM 的 话 ， 这 个 地 址 就 会 被 其 占用 ， 而 RAM 板 则 转 到 
更 高 的 地 址 。 


命令 处 理 程序 的 使 用 极 大 地 推动 了 计算 机 的 发 展 ， 通 过 它 不 仅 可 以 更 快 地 向 存储 器 
输入 数据 ， 更 重要 的 是 ， 计 算 机 变 得 可 交互 (interactive ) 了 。 当 你 通过 键盘 输入 一 些 内 
容 ， 计 算 机 会 立即 做 出 响应 ， 把 你 所 输入 的 内 容 显示 出 来 。 


将 命令 处 理 程序 存储 到 ROM 后 , 就 可 以 执行 操作 了 : 把 内 存 中 的 数据 写 入 到 磁盘 驱动 
器 〈 可 能 是 按照 与 磁盘 的 局 区 大 小 一 致 的 块 的 形式 )， 然 后 再 把 数据 读 回 到 内 存 中 。 因 为 掉 
电 的 时 候 ，RAM 中 的 内 容 会 丢失 ， 所 以 与 RAM 相 比 ， 把 程序 和 数据 存储 到 磁盘 中 会 更 安 
全 (它们 不 会 因为 突然 断 电 而 丢失 数据 )， 就 灵活 性 来 说 ， 也 比 存储 到 ROM 中 要 好 。 


仅仅 有 上 面 的 命令 还 是 不 够 的 , 还 需要 向 命令 处 理 程序 中 添加 新 命令 。 例 如 ，S 命 
表示 存储 (Store ): 


3S 2080 2 15 3 


运行 这 条 命令 后 ， 在 磁盘 的 第 2 面 、 第 15 道 、 第 3 扇 区 中 将 存放 起 始 地 址 为 2080h 
的 内 存 块 数据 (被 存放 内 存 块 的 大 小 是 由 磁盘 遍 区 的 大 小 决定 的 )。 类 似 地 ， 还 可 以 通过 
加 载 (Load ) 命令 ， 把 磁盘 上 相应 扇 区 的 内 容 写 回 到 内 存 中 ， 如 下 所 示 : 


L 2080 2 15 3 


当然 ， 还 要 把 存储 的 位 置 记 录 下 来 ， 这 是 必须 要 做 的 。 你 可 以 用 手头 上 的 纸 和 笔 来 
完成 。 需 要 注意 的 是 : 你 不 能 把 位 于 某 个 地 址 处 的 代码 又 加 载 到 内 存 的 另外 一 个 地 址 中 ， 
如 果 这 样 的 话 ， 程 序 将 不 能 正常 运行 。 具 体 来 说 ， 程 序 代码 在 内 存 中 改变 位 置 后 ， 其 跳 
转 (Jump ) 和 调用 ( Call ) 指令 标识 的 依然 是 原来 的 地 址 ， 所 以 运行 时 会 报错 。 也 存在 这 
样 的 情况 ， 程 序 比 磁盘 的 扇 区 大 ， 这 时 就 需要 多 个 肩 区 来 存放 程序 。 而 磁盘 上 某 些 肩 区 

已 被 其 他 程序 或 数据 占用 了 ， 而 另外 一 些 肩 区 是 空闲 的 ， 可 能 在 磁盘 上 找 不 到 一 块 足够 
大 的 、 连 续 的 肩 区 来 存放 程序 。 


最 后 ， 所 有 的 东西 存储 在 磁盘 的 什么 位 置 ， 都 需要 你 手工 地 记录 下 来 ， 这 个 工作 挺 
多 ， 也 挺 麻 烦 。 出 于 这 个 原因 ， 文 件 系统 (file system ) 应 运 而 生 。 


文件 系统 是 磁盘 存储 的 一 种 方法 ， 就 是 把 数据 组 织 成 文件 《file )。 简单 地 说 , 文件 是 
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相关 数据 的 集合 ， 占 用 磁盘 上 一 个 或 多 个 扇 区 。 更 重要 的 是 ， 你 可 以 为 每 个 文件 命名 ， 
这 有 助 于 记 下 文件 里 存放 的 内 容 。 想 象 一 下 ， 磁 盘 是 不 是 类 似 于 一 个 文件 柜 ， 每 个 文件 
都 有 个 小 标签 ,标签 上 有 文件 的 名 称 。 


操作 系统 (operating system ) 是 许多 软件 构成 的 庞大 程序 集合 ,文件 系统 就 是 其 中 的 
一 部 分 。 前 面 讲 到 的 键盘 处 理 程序 和 命令 处 理 程序 最 终 也 能 经 过 拓展 ， 演 变 成 为 操作 系 
统 。 那 么 操作 系统 到 底 能 够 做 些 什么 、 又 是 如 何 工作 的 呢 ? 这 里 皂 开 操作 系统 漫长 的 发 
展演 化 过 程 ， 把 重点 放 在 刚才 提出 的 问题 上 ， 目 的 就 是 试图 让 大 家 了 解 操作 系统 的 工作 
机 制 。 


如 果 你 对 操作 系统 的 发 展 史 有 一 定 了 解 的 话 , 你 就 会 知道 CP/M ( Control Program for 
Micros ) 是 最 重要 的 8 位 微 处 理 器 操作 系统 ， 它 是 20 世纪 70 年 代 中 期 由 加 里 基 尔 代 尔 
(Gary Kildall， 生 于 1942 年 ) 专门 为 Intel 8080 微 处 理 器 而 开发 的 ， 加 里 后 来 成 了 DRI 
(Digital Research Incorporated ) 公司 的 创始 人 。 


CP/M 操作 系统 是 存放 在 磁盘 上 的 。 单 面 、8 英寸 的 磁盘 是 早期 的 CP/M 最 常用 的 存 
储 介质 ， 它 有 77 个 磁道 ， 每 个 磁道 有 26 个 扇 区 ， 每 个 扇 区 的 大 小 是 128 个 字 节 (总共 
算 下 来 共有 256,256 个 字 节 ) CP/M 系统 存放 在 磁盘 最 开始 的 两 个 磁道 在 启动 计算 机 时 ， 
需要 把 CP/M 从 磁盘 调 入 到 计算 机 的 内 存 中 ， 下 面 将 介绍 这 一 过 程 是 如 何 进行 的 。 


上 面 我 们 讲 过 ， 存 放 CP/M 本 身 只 占用 2 个 磁道 ， 那 么 剩 下 的 75 个 磁道 用 来 存储 文 
件 。CP/M 的 文件 系统 固然 简单 ， 但 两 个 最 基本 的 要 求 还 是 可 以 满足 的 。 首 先 ， 每 个 文件 
在 磁盘 中 都 有 属于 自己 的 名 字 ， 便 于 识别 ， 这 个 名 字 也 是 存放 在 磁盘 中 的 ; 实际 上 , 文 ， 
件 以 及 读 取 这 些 文 件 需要 的 所 有 信息 也 是 一 起 存储 在 磁盘 中 的 。 其 次 ， 文 件 存储 在 磁盘 
中 不 一 定 要 占据 连续 的 扇 区 空间 ， 可 以 想象 ， 由 于 大 小 不 同 的 文件 会 被 经 常 地 创建 和 删 
除 ， 磁盘 上 的 可 用 空间 就 会 很 零碎 。 那 么 如 何 将 文件 存储 在 零碎 的 空间 里 呢 ?” 这 主要 得 
益 于 文件 系统 具有 很 强大 的 管理 功能 ， 它 可 以 把 一 个 大 文件 分 散 存储 在 不 连续 的 磁盘 上 。 

上 面 曾 提 到 过 剩 下 的 75 个 磁道 中 的 扁 区 用 来 存放 文件 ,这 些 记 区 按 分 配 块 ( allocation 
blocks ) 进行 分 组 。 每 个 分 配 块 中 有 8 个 扁 区 ， 总 计 1024 个 字 节 (每 个 扁 区 大 小 是 128 
字 节 )。 可 以 计算 ， 在 磁盘 上 共有 243 个 分 配 块 ， 编 号 为 0~ 242。 


目录 ( directory ) 区 占用 最 开始 的 两 个 分 配 块 (编号 为 0 和 1， 总 共 2048 字 节 ) 中 。 
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编码 - ”隐匿 在 计算 机 软 硬 件 背后 的 语言 


目录 区 是 磁盘 中 的 一 个 非常 重要 的 区 域 ， 磁 盘 文 件 中 每 个 文件 的 名 字 和 其 他 一 些 重要 信 
息 都 存储 在 该 区 域 ， 根 据 目 录 就 能 够 很 方便 、 高 效 地 查找 文件 。 存 放 目 录 也 需要 占用 空 
间 ， 磁 盘 上 每 个 文件 对 应 的 目录 项 ( directory entry ) 大 小 均 为 32 字 节 ， 由 于 目录 区 大 小 
为 2048 字 节 ， 所 以 这 个 磁盘 上 最 多 可 以 存放 64 (2048/32 ) 个 文件 。 


为 了 能 够 根据 目录 找到 相应 的 文件 ， 每 一 个 32 字 节 的 目录 项 包含 以 下 信息 。 


保留 (设置 为 0) 
磁盘 存储 表 


在 目录 项 中 ， 第 一 个 字 节 用 来 设置 文件 的 共享 属性 ， 只 有 文件 系统 被 两 个 或 更 多 人 


同时 共享 时 才 设 置 此 字 节 为 1。 在 CP/M 中 ， 这 个 字 节 跟 第 13、14 字 节 一 样 ， 通 常设 置 
为 0。 


CPM 中 每 个 文件 的 文件 名 由 两 部 分 构成 ， 第 一 部 分 称 为 文件 名 〈filename )， 文 件 
名 最 多 由 8 个 字符 构成 ， 目 录 项 的 第 1 ~8 字 节 用 来 存储 文件 名 。 第 二 部 分 称 为 文件 类 型 
( file type )， 最 多 由 3 个 字符 表示 ， 这 些 字 符 存储 在 目录 项 的 第 9~ 11 字 节 中 。 我 们 会 经 
常 遇 到 一 些 常 见 的 标准 文件 类 型 ， 例 如 : TXT 表示 文本 文件 (此 文件 只 包含 ASCII 码 ); 
COM( command 的 简写 ) 表 示 这 个 文件 中 存放 的 是 8080 机 器 码 指令 , 或 者 说 是 一 段 程序 。 
当 命 名 一 个 文件 时 ， 通 过 一 个 点 来 隔 开 这 两 部 分 ， 如 下 所 示 : 


MYLETTER.TXT 
CALC.COM 


人 们 习惯 形象 地 称 这 种 文件 命名 方式 为 8.3， 就 是 说 在 点 号 隔 开 的 前 半 部 分 最 多 有 8 
个 字母 ， 后 半 部 分 最 多 有 3 个 字母 。 


接 下 来 介绍 一 下 如 何 利用 目录 项 查找 文件 .目录 项 中 的 第 16~ 31 字 节 是 磁盘 存储 表 ， 
它 能 够 标明 文件 所 存放 的 分 配 块 。 假 设 磁盘 存储 表 的 前 4 项 分 别 为 14h、15h、07h、23h， 
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其 余 项 全 为 0， 这 表明 文件 占用 了 4 个 分 配 块 的 空间 ， 大 小 为 4 KB， 而 实际 上 文件 可 能 
并 没有 用 完 4 KB 空间 ， 因 为 最 后 一 个 分 配 块 往往 只 有 部 分 扇 区 被 使 用 。 目 录 项 的 第 15 
字 节 表明 最 后 一 个 分 配 块 到 底 用 到 了 多 少 个 128 字 节 的 扇 区 。 


磁盘 存储 表 的 长 度 为 16 字 节 ， 最 多 可 以 容纳 16,384 字 节 (16 KB ) 的 文件 ， 如 果 文 . 
件 的 长 度 超过 16 KB， 就 需要 用 多 个 目录 项 来 表示 ， 这 种 方法 称 为 扩展 〈extents )。 如 果 
一 个 大 文件 使 用 目录 项 扩展 来 ， 则 将 第 一 个 目录 项 的 第 12 字 节 设置 为 0， 第 二 个 目录 项 
的 第 12 字 节 则 设置 为 1， 依 此 类 推 。 

文本 文件 对 我 们 并 不 陌生 ， 通 常 也 称 之 为 ASCI 文件 (ASCI file )、 纯 文本 文件 
( text-only file ) 或 纯 ASCH 文件 (pure-ASCII file )， 当 然 还 有 其 他 一 些 类 似 的 名 称 。ASCI 
码 (包括 换行 符 和 回 车 符 ) 是 文本 文件 中 唯一 包含 的 字符 ， 文 本 文件 通俗 易 懂 ， 便 于 浏 
览 。 除 了 文本 文件 外 ， 其 余 的 文件 称 为 二 进 制 文件 (binary file), 在 CMIP 中 ，COM 文 
件 存放 的 是 二 进 制 的 8080 机 器 码 ， 它 是 二 进 制 文件 。 

假设 一 个 小 文件 中 包含 三 个 16 位 数 ， 如 : 5A48h、78BFh 和 F510h。 如 果 此 文件 是 
二 进 制 文件 ， 只 要 6 字 节 就 可 以 了 。 

48 5A BF 78 10 FS 

这 是 采用 Intel 格式 来 存储 的 ， 放 在 前 面 的 是 低位 ， 放 在 后 面 的 是 高 位 。 并 不 是 所 有 
的 数据 都 是 按照 这 种 格式 来 存储 的 ， 例 如 为 Motorola 处 理 器 编写 的 程序 更 倾向 于 按 以 下 
的 方式 来 组 织 文件 : 


5A 48 78 BF FS5 10 


假如 上 面 的 三 个 16 位 数 用 ASCI 文本 文件 来 存放 ， 则 文件 中 保存 的 数据 如 下 所 示 : 


35 41 34 38 68 0D 0A 37 38 42 46 68 0D 0A 46 35 31 30 68 0D 0A 


上 面 的 这 些 字 节 是 数字 和 字母 的 ASCI 码 表示 形式 , 用 回 车 符 (0Dh ) 和 换行 符 ( 0Ah ) 
来 表示 每 一 个 数 的 结束 。 因 为 文本 文件 可 以 不 通过 解释 相应 的 ASCII 字 节 串 来 显示 字符 ， 
而 是 将 字符 本 身 直接 显示 ， 所 以 显得 更 加 方便 ， 如 下 所 示 : 


5A48h 
78BFh 
F510n 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
tf 


! 


也 可 以 用 如 下 的 形式 来 表示 包含 这 三 个 数 的 ASCII 文本 文件 : 


32 33 31 31 32 0D 0A 33 30 393 31 0D 0A 36 32 37 33 36 0D 0A 


这 是 用 十 进 制 数 的 ASCH 码 形式 来 表示 上 述 三 个 数 ， 这 两 种 表示 形式 是 等 价 的 ， 如 


下 所 示 : 


23112 
30911 
62736 


显然 ， 文 本 文件 更 易于 人 们 阅读 ， 同 样 ， 与 十 六 进 制 相 比 ， 十 进 制 更 符合 人 们 的 习 


惯 , 没 理由 使 用 十 六 进 制 而 拒绝 十 进 制 。 


前 面 曾 提 到 过 , 磁盘 最 开始 的 两 个 磁道 存储 CP/M 系统 本 身 , 而 CP/M 在 磁盘 上 是 无 
法 运行 的 ， 必 须 将 其 加 载 到 内 存 里 。 只 读 存储 器 (ROM ) 在 CP/M 计算 机 中 使 用 得 并 不 
多 ， 只 需要 用 它 来 存放 一 小 段 称 为 引导 程序 bootstrap loader， 操 作 系统 的 其 余部 分 可 以 
通 这 段 代 码 的 自 举 操作 锌 高 效 地 引导 ) 的 代码 即 可 。 开 机 启动 时 ， 磁 盘 上 最 开始 的 128 
字 节 的 扇 区 内 容 ， 会 首先 由 引导 程序 加 载 到 内 奉 并 运行 ， 这 个 肩 区 包含 有 特定 的 代码 ， 
可 以 把 CP/M 中 的 其 余部 分 加 载 到 内 存 中 ， 整 个 过 程 称 为 操作 系统 的 引导 〈booting )。 


操作 系统 的 引导 过 程 完 成 后 ， 随 机 存储 器 ( RAM ) 的 最 高 地 址 区 域 月 


加 载 完 CP/M 后 ， 整 个 内 存 空间 的 组 织 结构 如 下 所 示 。 
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0000h: 


0100h : 


临时 程序 区 域 
CTPAY 


控制 台 命令 处 理 程序 
(CCP) 


基本 磁盘 操作 系统 
(BDOS) 


基本 输入 /输出 系统 
(BIOS) 


有 来 存放 CP/M， 


li | 


该 图 仅仅 粗略 地 表示 出 了 内 存 各 构成 部 分 ， 没 有 按 比例 刻画 各 部 分 所 占 内 存 的 大 小 。 
控制 台 命令 处 理 程 序 ( Console Command Processor, CCP )、 基本 和 磁盘 操作 系统 (Basic Disk 
Operating System，BDOS ) 和 基本 输入 /输出 系统 (Basic Input/Output System，BIOS ) 是 
CP/M 的 三 个 组 成 部 分 ， 这 三 个 部 分 只 占用 了 6 KB 大 小 的 内 存 空间 。 在 拥有 64 KB 内 存 
空 空间 的 计算 机 中 ， 大 约 58 KB 被 临时 程序 区 (Transient Program Area，TPA ) 占用 ,但 是 
这 58 KB 空间 一 开始 时 是 空 的 。 


控制 台 命令 处 理 程序 的 功能 和 以 前 讨论 过 的 命令 处 理 程序 是 一 样 的 。 在 这 里 ， 键 盘 
和 显示 器 组 成 了 控制 台 (console )。 控 制 台 命令 处 理 程序 显示 如 下 所 示 的 命令 提示 符 
( prompt ): 


A> 


在 命令 提示 符 后 画 可 以 输入 一 些 信息 。 大 多 数 计算 机 可 能 有 不 止 一 个 磁盘 驱动 器 ， 
第 一 个 磁盘 驱动 器 标 为 A，CP/M 被 装载 到 该 驱动 器 中 。 在 命令 提示 符 后 面 融 入 命令 并 按 
回 车 (Enter ) 键 ,控制 台 命令 处 理 程序 会 执行 该 命令 ,然后 将 执行 的 结果 显示 到 屏幕 上 。 
执行 完 命令 后 ,命令 提示 符 又 会 显示 在 屏幕 上 ， 等待 下 一 次 输入 。 


控制 台 命 令 处 理 程序 只 能 识别 一 部 分 命令 ， 其 中 最 重要 的 命令 是 : 

DIR 

该 命令 用 于 显示 磁盘 的 目录 信息 ， 换 名 话说 ， 它 列 出 了 存储 在 磁盘 上 的 所 有 文件 。 
然而 有 时 候 需 要 查看 具有 特定 名 字 和 类 型 的 文件 ， 这 时 候 就 可 以 在 命令 中 使 用 像 “? ” 
和 “*” 这 样 的 特殊 字符 来 限定 。 如 果 想 显示 当前 目录 下 所 有 的 文本 文件 ， 可 以 使 用 如 下 


从 
虽 令 : 


DIR *.TXT 


而 


DIR A??2?B.* 


则 显示 所 有 文件 名 由 5 个 字符 构成 ， 其 中 第 一 个 字符 是 A， 最 后 一 个 字符 是 B 的 文件 。 
如 果 想 删除 磁盘 中 的 文件 ， 要 用 到 命令 ERA， 它 是 Erase 的 缩写 ， 例 如 : 


ERA MYLETTER.TXT 
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下 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


用 来 删除 名 为 MYLETTER.TXT 的 文件 ， 而 运行 下 面 的 命令 : 


ERA *.TXT 


则 所 有 的 文本 文件 都 被 删除 。 一 旦 旦 删除 文件 ， 此 文件 的 目录 项 及 其 所 占用 的 磁盘 空间 都 
将 被 释放 。 


REN 也 是 一 个 常用 命令 ， 它 是 Rename 的 缩写 ， 此 命令 可 以 改变 文件 名 。 如 果 想 显 
示 文 本 文件 的 内 容 ， 可 以 使 用 TYPE 命令 ， 这 条 命令 的 功能 还 不 仅 如 此 ， 要 知道 文本 文 
件 中 仅 包 含 ASCII 码 ， 所 以 屏幕 上 文件 的 内 容 也 可 以 通过 这 条 命令 来 浏览 ， 例 如 :， 


TYPE MYLETER.TXT 


表示 查看 MYLETER_TXT 文件 的 内 容 。SAVE 命令 用 来 保存 文件 ， 它 可 把 临时 存储 区 域 
中 的 一 个 或 多 个 256 字 节 的 内 存 块 保存 到 磁盘 中 ， 并 且 给 这 个 内 存 块 指定 一 个 名 字 。 


当然 ， 上 述 所 介绍 的 都 是 CP/M 可 识别 的 命令 , 如 果 你 输入 一 个 不 能 被 CP/M 识别 的 
命令 ，CP/M 就 会 默认 为 输入 的 是 保存 在 磁盘 上 的 一 个 程序 名 。 而 程序 通常 是 以 文件 形式 
存储 的 ， 其 文件 类 型 为 COM， 代 表 着 命令 。 控 制 台 命 令 处 理 程序 负责 在 磁盘 上 查找 此 文 
件 ， 如 果 找 到 ， 此 文件 会 被 CP/M 从 磁盘 加 载 到 临时 程序 区 域 ， 该 区 域 的 地 址 从 0100h 
开始 , 一旦 文件 被 调 入 内 在即 可 运行 。 上 面 从 流程 的 角度 介绍 了 磁盘 中 的 文件 是 如 何 被 
运行 的 ， 下 面 举 个 例子 来 说 明 。 假 如 在 CP/M 命令 提示 符 后 面 输入 : 


CALC 


如 果 在 磁盘 中 存在 名 为 CALC.COM 的 文件 , 则 该 文件 会 被 控制 台 命令 处 理 程序 调 入 到 以 
地 址 0100h 开始 的 内 存 中 ， 接 着 控制 台 命令 处 理 程序 会 转 到 该 地 址 并 执行 这 段 程序 。 


前 面 介绍 了 如 何 将 机 器 码 指 令 插入 到 内 存 空间 的 任意 位 置 并 执行 。 但 是 存储 在 磁盘 
上 的 CP/M 程序 并 不 能 被 随意 存放 到 内 存 中 的 任意 位 置 , 它 必 须 被 加 载 到 指定 的 位 置 , 在 
这 里 是 以 0100h 开始 的 内 存 空间 。 


CP/M 由 一 些 实用 的 程序 组 成 ， 如 PIP (Peripheral Interchange Program )， 即 外 设 交换 
程序 ， 通 过 它 可 以 复制 文件 。ED 是 文本 编辑 器 ， 可 以 创建 和 修改 文本 文件 。 在 CP/M 系 
统 中 ， 有 很 多 像 PIP 和 ED 一 样 的 程序 ， 它 们 很 小 但 可 以 完成 简单 的 事务 处 理 ， 这 类 程序 
称 为 实用 (utility ) 程序 。 仅 仅 有 这 些小 的 简单 程序 是 远 远 不 够 的 ， 还 有 一 些 大 的 商业 化 
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应 用 程序 (application )， 比 如 字 处 理 软件 或 计算 机 电子 报表 软件 等 , 在 CP/M 系统 中 ,这 
些 软件 的 使 用 会 给 你 的 工作 带 来 很 大 方便 。 当 然 ， 如 果 你 是 一 个 程序 开发 高 手 ， 也 可 以 
自己 动手 编写 这 些 软 件 ， 这 些 程序 的 存储 类 型 都 是 COM 文件 类 型 。 


在 CPM ( 跟 许 多 操作 系统 一 样 ) 中 , 我 们 了 解 了 很 多 内 容 ， 比 如 如 何 利用 命令 和 实 
用 程序 对 文件 进行 基本 操作 ， 如 何 将 程序 加 载 到 内 存 中 并 运行 等 。 操 作 系 统 的 功能 远 不 
止 如 此 ， 下 面 将 介绍 它 的 第 三 个 重要 功能 。 


前 面 提 到 过 ， 把 输出 信息 写 到 视频 显示 器 上 ， 或 者 从 键盘 读 取 输 入 的 内 容 ， 或 者 读 / 
写 磁盘 中 的 文件 , 这 些 都 是 运行 在 CP/M 下 的 程序 常常 要 做 的 操作 。 这 就 需要 CP/M 程序 
能 够 直接 向 视频 显示 器 的 内 存 写 入 输出 内 容 , 也 需要 CP/M 程序 能 够 访问 键盘 硬件 来 捕获 
所 输入 的 内 容 ， 还 需要 CP/M 程序 能 够 访问 磁盘 驱动 器 来 读 / 写 磁 盘 鹿 区， 然而 在 通常 情 
况 下 程序 本 身 是 很 难 直接 做 到 的 。 


那么 有 没有 别 的 方法 来 实现 上 述 的 要 求 呢 ? 管 案 是 表 定 的 , 这 些 常用 事务 由 CP/M 中 
的 子 程序 集 来 完成 , 在 CP/M 下 运行 的 程序 通过 调用 这 些 子 程序 即 可 完成 相应 的 操作 。 这 
些 子 程序 都 是 专门 设计 的 ， 计 算 机 中 的 所 有 硬件 都 可 以 很 容易 地 通过 它们 来 访问 ， 如 视 
闫 显示 器 、 键 盘 、 磁 盘 驱动 器 等 ， 而 程序 员 无 须 关心 这 些 外 设 实际 是 如 何 连接 的 。 更 是 
要 的 是 ， 像 磁道 、 扇 区 这 类 信息 ， 程 序 没有 必要 知道 ， 这 些 工 作 都 是 由 CP/M 来 完成 的 ， 
它 可 以 负责 读 / 写 磁盘 上 的 文件 。 


操作 系统 提供 的 第 三 个 主要 功能 是 让 程序 能 够 方便 地 访问 计算 机 的 硬件 ， 操 作 系统 
提供 的 这 种 访问 操作 称 为 API ( Application Programming Interface )， 即 应 用 程序 接口 。 


Man 


那么 如 何 设置 和 使 用 API 呢 ? 在 CPM 下 运行 的 程序 ， 可 以 通过 将 寄存 器 C 设置 为 
特定 的 值 《 称 为 功能 值 )， 并 且 运 行 如 下 指令 : 


CALL 5 


来 使 用 API。 例 如 ,你 从 键盘 上 按 下 了 一 个 键 , 程序 会 通过 执行 下 面 的 指令 来 获取 此 键 对 
应 的 ASCI 码 : 


MVI C,01lh 
CALL 5 


并 且 将 这 个 键 的 ASCI 码 值 保存 在 累加 器 A 中 。 类 似 的 ， 运 行 这 条 命令 : 
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编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


MVI C,02h 
CALL 5 


在 视频 显示 器 上 当前 的 光标 位 置 将 显示 累加 器 A 中 的 ASCII 码 字符 ， 然 后 光标 移 到 下 一 
个 位 置 。 

如 果 程 序 要 新 建 一 个 文件 ， 它 首先 将 文件 名 所 在 区 域 的 地 址 保存 在 寄存 器 对 DE 中 ， 
接着 执行 如 下 代码 : 


MVI C,16h 
CALL 5 


执行 此 命令 ，CP/M 会 在 磁盘 上 新 建 一 个 空 文件 。 程 序 可 以 利用 CP/M 提供 的 其 他 功 
能 来 向 空 文件 中 写 入 内 容 ， 最 后 关闭 ( close ) 文件 ， 关 闭 文件 意味 着 文件 使 用 完毕 ,不 
需要 在 对 该 文件 执行 任何 操作 了 。 当然 , 该 文件 可 以 再 次 被 此 程序 和 其 他 程序 打开 ( open ) 


CALL 5 指令 到 底 如 何 工作 呢 ? CP/M 在 内 存 中 地 址 为 0005h 处 设置 了 一 条 JMP 
(Jump ) 指令 ， 它 跳 转 到 CP/M 基本 磁盘 操作 系统 ( Basic Disk Operating System，BDOS ) 
中 的 某 个 位 置 。 这 个 区 域 包含 许多 小 程序 ，CP/M 的 每 一 项 功能 都 可 由 它们 完成 。BDOS ， 
顾名思义 ， 它 的 主要 功能 是 维护 磁盘 上 的 文件 系统 。 文 件 系统 经 常 要 与 终端 设备 打交道 ， 
所 以 BDOS 经 常 要 调用 CP/M 基本 输入 /输出 系统 ( Basic Input And Output System，BIOS ) 
中 的 一 些 子 程序 。 这 里 顺便 提 一 下 ，BIOS 可 以 对 硬件 进行 访问 ， 比 如 键盘 、 视 频 显 示 器 
和 磁盘 驱动 器 等 。 实 际 上 ，BIOS 是 CP/M 中 唯一 需要 了 解 计算 机 中 硬件 的 程序 ， 其 他 一 
些 对 硬件 的 操作 都 可 通过 调用 BIOS 中 的 子 程序 来 实现 。 控 制 台 命 令 处 理 程序 通过 调用 
BDOS 的 子 程序 来 实现 自己 所 有 的 功能 ， 而 在 CP/M 中 运行 的 程序 也 是 这 样 。 


对 于 计算 机 硬件 来 说 , API 是 一 个 与 设备 无 关 ( device-independent ) 的 接口 。 换言之， 
对 于 特定 的 机 器 上 键 总 的 工作 机 制 、 视 频 显示 器 的 工作 机 制 以 及 磁 益 扇 区 的 读 / 写 机 人 制 ， 
在 CPM 下 编写 的 程序 不 需要 知道 也 没有 必要 知道 。 程序 使 用 CP/M 提供 的 功能 便 可 完成 
对 键盘 、 视 频 显 示 器 和 磁盘 驱动 器 操作 , 简 言 之 , API 屏蔽 了 硬件 之 间 的 差异 。 有 了 APL， 
尽管 不 同 计算 机 硬件 差别 很 大 , 其 访问 外 设 的 方式 也 不 尽 相 同 , 但 CP/M 程序 都 可 以 在 上 
面 运 行 , 从 而 实现 了 CP/M 程序 的 跨 平 台 ( 这 里 要 求 所 有 CP/M 程序 必须 运行 在 Intel 8080 
微 处 理 器 上 , 或 者 运行 在 能 执行 Intel 8080 指令 的 处 理 器 上 , 例如 Intel 8085 或 Zilog Z-80 
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处 理 器 )。 所 以 ,在 使 用 CP/M 系统 的 计算 机 中 ， 程 序 对 硬件 访问 是 通过 CP/M 来 实现 的 。 
如 果 没有 标准 的 API， 程 序 必 须根 据 不 同型 号 的 计算 机 进行 相应 的 修改 后 ， 才 能 访问 硬件 。 


CP/M 是 8080 中 非常 流行 的 操作 系统 ， 曾 经 辉煌 一 时 ， 至 今 仍 有 重要 的 历史 意义 。 

16 位 操作 系统 QDOS( Quick and Dirty Operating System ) 的 开发 在 很 多 方面 都 借鉴 了 CP/M 
的 思想 。QDOS 当初 是 专 为 英特尔 公司 的 16 位 8086 和 8088 芯片 而 设计 的 ， 它 出 自 西 雅 
图 计算 机 产品 公司 ( Seattle computer product ) 的 提 姆 . 帕 特 森 之 手 。QDOS 系统 被 微软 
公司 注册 后 更 名 为 86-DOS。1981 年 ， 随 着 IBM 第 一 代 PC 诞生 ， 微 软 公司 也 将 86-DOS 
更 名 为 MS-DOS (Microsoft Disk Operating System )， 并 以 此 名 授权 给 IBM 公司 用 作 第 一 
代 个 人 计算 机 的 操作 系统 。 这 就 是 著名 的 MS-DOS 系统 ， 在 现在 的 计算 机 中 也 会 经 常 看 
到 它 的 身影 。 虽然 16 位 版 本 的 CP/M( 称 为 CP/M-86 ) 也 可 用 于 IBM PC , 但 由 于 MS-DOS 
的 影响 力 更 大 ， 其 很 快 成 为 了 标准 。 其 他 生产 IBM PC 兼容 机 的 厂商 也 被 授权 使 用 
MS-DOS (在 IBM 计算 机 上 称 为 PC-DOS ) 系统 。 


CP/M 的 文件 系统 在 MS-DOS 没有 被 继续 使 用 ， 在 MS-DOS 中 ， 文件 系 统 是 以 文件 
分 配 表 (FAT，File Allocation Table 的 简写 ) 的 形式 来 组 织 的 ，Microsoft 公司 早 在 1977 
年 就 开始 使 用 FAT 了 。FAT 的 基本 思想 是 : 将 磁盘 空间 分 成 篮 ( cluster ) 簇 的 大 小 由 
磁盘 空间 的 大 小 来 决定 一 一 从 512 字 节 到 16 K 字 节 不 等 ， 每 个 文件 占用 若干 签 。 文 件 的 
目录 项 只 记录 文件 起 始 ( starting ) 敌 的 位 置 ， 而 和 磁盘 上 每 一 复 的 下 一 纂 的 位 置 由 FAT 来 
记录 。 


每 个 目录 项 在 MS-DOS 磁盘 上 占用 32 字 节 ,其 命名 形式 跟 CP/M 上 的 8.3 形式 一 样 ， 
只 是 使 用 的 术语 有 些 区 别 : 最 后 的 三 个 字符 称 做 文件 扩展 名 ， 而 非 CP/M 中 的 文件 类 型 。 
MS-DOS 目录 项 中 没有 包含 分 配 块 列表 ， 它 主要 包含 如 下 所 示 的 有 用 信息 : 文件 的 最 后 
修改 的 日 期 、 时 间 和 文件 的 大 小 等 。 


实际 上 ，MS-DOS 的 早期 版 本 与 CP/M 在 结构 上 很 类 似 ， 只 是 IBM PC 本 身 在 ROM 
中 已 经 包含 了 一 套 完整 的 BIOS 了 ， 所 以 在 MS-DOS 中 不 再 需要 BIOS。 在 MS-DOS 中 ， 
命令 处 理 器 是 一 个 命名 为 COMMAND.COM 的 文件 。MS-DOS 有 两 种 运行 程序 ， 一 是 以 
COM 为 扩展 名 的 文件 ， 其 大 小 不 能 超过 64 KB， 一 是 更 大 些 的 程序 ， 以 EXE (意思 是 
可 以 被 执行 ) 为 文件 的 扩展 名 ， 表 明文 件 本 身 是 可 执行 的 。 


尽管 MS-DOS 起 初 支持 API 函数 的 CALL 5 接口 , 但 不 久 Microsoft 为 新 的 程序 重新 
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设计 了 一 款 新 的 接口 。 这 个 新 的 接口 使 用 了 8086 的 一 个 称 为 软件 中 断 ( software interrupt ) 
的 功能 ， 说 起 软件 中 断 ， 它 与 子 程序 调用 很 类 似 ， 只 不 过 程序 不 必 知 道 它 所 调用 的 子 程 
序 的 确切 地 址 。 通 过 执行 INT 21h 这 条 指令 ， 程 序 可 以 调用 MS-DOS 的 API 功能 。 


”从 理论 上 讲 ， 应 用 程序 并 不 能 直接 访问 计算 机 的 硬件 ， 如 果 它 要 访问 计算 机 的 硬件 ， 
可 以 通过 操作 系统 提供 的 接口 来 进行 。 然 而 实际 上 ， 在 20 世纪 70 年 代 末 和 80 年 代 初 ， 
由 于 计算 机 上 运行 的 都 是 小 型 操作 系统 ， 许 多 应 用 程序 往往 都 绕 过 它们 ， 这 种 情况 在 处 
理 有 关 视 频 显 示 器 任务 的 时 候 显 得 特别 明显 。 为 什么 会 这 样 呢 ? 因为 如 果 程 序 把 字 节 直 
接 写 入 视频 显示 存储 器 ， 它 的 执行 速度 要 远 快 于 不 直接 写 入 视频 显示 存储 器 。 事 实 上 ， 
对 于 一 些 程序 一 一 比如 要 将 图 形 显示 在 视频 显示 器 上 一 一 操作 系统 就 显得 “ 心 有 余 而 力 不 
足 ”, 这 就 需要 在 操作 系统 之 外 另 作 处 理 。 也 许 正 是 因为 MS-DOS 系统 卓越 的 “ 反 传统 性 ”， 
使 得 大 多 数 程序 员 都 很 热衷 于 它 ， 它 可 以 让 程序 员 编 写 的 程序 最 大 限度 地 达到 硬件 的 最 
快速 度 ， 更 加 充分 地 发 挥 硬件 的 性 能 。 


恰恰 是 这 个 原因 ， 运 行 在 BM PC 上 的 流行 软件 通常 依赖 于 IBM PC 这 个 硬件 平台 ， 
换 名 话说， 就 是 这 些 软件 是 根据 IBM PC 的 硬件 特点 编制 的 。 为 了 和 IBM PC 竞争 ,其 他 
机 器 制造 商 不 得 不 沿 缆 这 些 特点 。 如 果 不 这 样 做 的 话 ， 再 流行 的 软件 也 将 流行 不 起 来 ， 
因为 它 不 能 在 这 些 机 器 上 运行 。 所 以 在 软件 的 显著 位 置 往往 会 出 现 “ 与 BM PC 百分之百 
兼容 ”的 字样 ， 这 同时 体现 了 软件 对 硬件 的 要 求 。 


微软 于 1983 年 3 月 发 布 了 MS-DOS 2.0 版 本 ， 与 最 开始 的 版 本 相 比 ， 它 加 强 了 对 硬 
盘 驱 动 器 的 管理 。 虽 然 当时 的 硬盘 容量 很 小 〔 按 今天 的 标准 )， 但 是 发 展 很 快 ， 没 经 过 多 
久 ， 硬 盘 的 容量 变 得 越 来 越 大 。 这 带 来 了 不 少 问题 ， 硬 盘 容量 越 大 存储 的 文件 也 就 越 多 ， 
存储 的 文件 越 多， 当然 ， 查 找 某 个 指定 的 文件 或 组 织 文件 也 就 越 困难 。 


为 了 解决 上 述 问 题 ，MS-DOS 2.0 引入 了 层次 文件 系统 hierarchical file system )， 它 只 
是 在 原 有 MS-DOS 的 文件 系统 上 做 了 一 些小 的 改动 。 前 面 介绍 过 ， 是 录 存 储 在 磁盘 中 特定 
区 域 ， 它 是 一 个 文件 列表 ， 包 含 了 文件 存储 在 磁盘 位 置 的 信息 。 在 层次 文件 系统 中 ， 有 些 
文件 其 本 身 可 能 就 是 目录 ， 也 就 是 说 这 些 文件 包含 其 他 文件 ， 其 中 的 一 些 可 能 还 是 目录 。 
在 磁盘 中 ， 目 录 的 称 法 也 是 有 讲究 的 ， 常 规 的 目录 称 为 根 目 录 ( root directory )， 子 目录 
(subdirectories ) 是 包含 在 其 他 目录 里 的 目录 。 有 了 目录 (有 时 称 文件 夹 ，folder )， 就 可 以 
很 方便 地 对 相关 文件 进行 分 组 ， 所 以 目录 在 磁盘 文件 的 管理 中 起 着 非常 重要 的 作用 。 
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讲 到 操作 系统 ， 我 们 不 能 不 提 到 著名 的 UNIX 系统 ， 它 在 操作 系统 的 发 展 史上 有 着 
举足轻重 的 地 位 。 实 际 上 , 层次 文件 系统 和 MS-DOS 2.0 的 其 他 很 多 功能 都 是 从 UNIX 操 
作 系 统 借鉴 而 来 的 。UNIX 操作 系统 是 20 世纪 70 年 代 初 在 贝尔 实验 室 开 发 的 ， 肯 … 汤 普 
森 (Ken Thompson， 生 于 1943 年 ) 和 丹尼斯 . 里 奇 (Dennis Ritchie， 生 于 1941 年 ) 是 
此 系统 的 主要 开发 者 。UNIX 系统 ( 包括 名 字 本 身 ) 的 发 展 历程 在 这 里 要 提 - 一 下 ，UNIX 
系统 来 源 于 早期 的 Multics ( Multiplex Information and Computing Services， 表 示 多 路 复 用 
信息 和 计算 业务 )，Multics 是 贝尔 实验 室 和 MIT ( 麻 省 理工 大 学 ) 和 GE (通用 电气 公司 ) 
合作 开发 的 一 个 项 目 ， 开 发 初期 由 于 Multics 没 能 达到 预定 的 目的 而 且 进 度 缓慢 ， 加 之 昂 
贵 的 开发 代价 ，1969 年 贝尔 实验 室 退 出 了 该 项 目 , 但 肯 : 汤普森 和 丹尼斯 里 奇 继续 对 
此 进行 了 开发 ， 为 了 区 别 于 Multics， 取 名 为 UNIX。 

对 于 计算 机 核心 程序 开发 的 精英 们 来 说 ,UNIX 无 疑 是 最 受 欢 迎 的 操作 系统 。 以 前 大 
部 分 操作 系统 是 针对 特定 的 计算 机 硬件 平台 开发 的 , 但 UNIX 打破 了 常规 ， 它 不 针对 具 
体 的 计算 机 硬件 平台 , 具有 很 好 的 可 移植 性 ( portable )， 也 就 意味 着 它 在 各 种 机 器 上 都 可 
以 运行 。 


在 开发 UNIX 的 时 候 ， 贝 尔 实验 室 是 电信 业 巨 头 AT&T (American Telephone && 
Telegraph， 美 国电 话 电报 公司 ) 旗下 的 一 员 ， 为 了 限制 AT&T 在 电话 业务 的 垄断 地 位 ， 
法 院 裁定 禁止 AT&T 销售 UNIX 系统 ，AT&T 被 迫 将 它 授权 给 别人 。 因 此 从 1973 年 初 ， 
很 多 大 学 、 公 司 和 政府 机 构 被 授权 使 用 和 研究 UNIX, 这 在 一 定 程 度 上 促进 了 UNIX 的 发 
展 。1983 年 ，AT&T 获准 重 返 计 算 机 业务 并 发 布 了 它 自 己 的 UNIX 版 本 。 


由 于 UNIX 的 广泛 授权 导致 了 许多 不 同 版 本 共存 的 情况 ， 它 们 使 用 着 不 同 的 名 字 ， 
运行 在 不 同 的 计算 机 上 ， 并 由 不 同 的 经 销 商 销售 。 由 于 UNIX 的 影响 力 和 开源 性 ， 使 得 
很 多 人 将 精力 投入 到 UNIX 中 并 推动 着 它 的 不 断 发 展 。 当 人 们 向 UNIX 中 添加 新 的 组 件 
时 ， 无 形 之 中 流行 着 一 种 不 成 文 的 “UNIX 思想 ”。 在 这 种 思想 的 指导 下 ， 人 们 都 使 用 文 
本 文件 作为 公用 文件 形式 。 许 多 UNIX 实用 程序 读 取 文本 文件 ， 利 用 它 提供 的 一 些 功能 
做 些 处 理 ， 然 后 将 其 写 入 另 一 个 文本 文件 。 因 此 可 以 用 链 的 形式 来 组 织 UNIX 实用 程序 ， 
然后 对 这 些 文本 文件 做 相应 的 处 理 。 


在 20 世纪 60-70 年 代 ， 计 算 机 不 仅 体积 庞大 而 且 价 格 昂贵 ， 仅 仅 为 一 个 人 服务 显然 
个 太 现实 ， 为 了 能 够 让 多 个 人 同时 使 用 计算 机 ， 必 须 有 相应 操作 系统 来 支持 ， 这 也 就 是 
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”开发 UNIX 系统 的 最 初 目的 。 使 用 UNIX 系统 的 计算 机 通过 时 分 复 用 (time sharing ) 技术 
一 一 这 种 技术 允许 多 个 用 户 同 时 与 计算 机 进行 交互 一 -来 达到 这 个 目的 。 计 算 机 连接 多 个 
配备 了 显示 器 和 键盘 的 终端 ( terminals )， 每 个 用 户 通过 这 些 终端 访问 计算 机 。 通 过 在 所 
有 终端 间 的 快速 切换 ， 使 用 户 感觉 这 台 计 算 机 似乎 只 为 自己 工作 ， 而 其 实 计算 机 同时 在 
为 多 个 用 户 服务 。 


如 果 在 一 个 操作 系统 上 可 以 同时 运行 多 个 程序 ， 则 称 此 系统 为 多 任务 ( multitasking ) 
操作 系统 。 显 然 ， 与 CPM 和 MS-DOS 这 样 的 单 任务 的 系统 相 比 ， 这 种 操作 系统 要 复杂 
得 多 。 正 是 由 于 支持 多 任务 这 种 功能 ， 文 件 系统 变 得 很 复杂 ， 因 为 同一 个 文件 可 能 被 多 
个 用 户 间 时 访问 。 程 序 的 运行 需要 占用 内 存 空间 ， 多 任务 系统 就 要 考虑 内 存 的 分 配 问题 ， 
也 就 是 说 需要 进行 内 存 管理 (memory management )。 也 许 你 会 有 疑问 ， 多 道 程序 并 行 运 
行 需要 占用 大 量 内 存 ， 如 果 内 存 不 够 怎么 办 ? 为 此 ， 操 作 系 统 引 入 了 虚拟 内 存 〈virtual 
memory ) 技术 。 虚 拟 内 存 是 指 ， 在 磁盘 上 划 出 部 分 空间 用 做 保存 临时 文件 ， 程 序 把 暂时 
不 需要 用 的 内 存 块 放 到 临时 文件 里 ， 待 需要 时 再 把 它 调 入 内 存 。。 


UNIX 能 够 存在 并 发 展 到 现在 是 无 数 人 共同 努力 的 结晶 ， 如 今 FSF ( Free Software 
Foundation， 自 由 软件 基金 会 ) 和 GNU 项 目 为 推动 UNIX 的 发 展 注入 了 新 的 活力 ， 它 们 
都 是 由 理 查 德 * 斯 塔 门 (Richard Stalhman ) 创建 的 。GNU 意味 着 :“GNU 与 UNIX, 既 
要 划 清 界限 义 相 辅 相 成 ”。 项 目的 宗 由 是 : 创建 一 个 与 UNIX 系统 兼容 , 但 不 受 私有 
权限 制 的 操作 系统 和 开发 环境 。 在 这 个 项 目的 推动 下 ,涌现 出 了 许多 和 UNIX 兼容 的 实 
用 程序 和 工具 , 其 中 最 著名 的 要 算 Linux 系统 。Linux 系统 的 内 核 ( Core 与 Kernel 都 可 以 
表示 内 核 的 意思 ) 和 UNIX 的 是 完全 兼容 的 ， 它 的 大 部 分 程序 是 由 芬兰 的 李 纳 斯 托 沃 
兹 (Linus Torvalds ) 完成 的 。 由 于 Linux 系统 的 开源 性 ,近年 来 已 成 为 非常 流行 的 操作 系 
统 。 


从 20 世纪 80 年 代 中 期 开始 ， 开 发 大 型 的 、 复 杂 度 更 高 的 系统 成 为 了 操作 系统 发 展 
的 一 大 趋势 ， 例 如 苹果 公司 的 Macintosh 系统 和 微软 的 Windows 系统 ， 它 们 融合 了 图 形 
和 高 级 可 视 化 视频 显示 技术 ， 使 应 用 程序 变 得 更 易于 使 用 。 关 于 图 形 和 可 视 化 方面 的 发 
展 趋势 ， 我 们 将 在 本 书 的 最 后 一 章 进 一 步 介绍 。 
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数字 就 是 数字 ， 整 数 、 分 数 以 及 百分数 等 各 种 类 型 的 数字 与 我 们 形影不离 ， 它 几乎 
出 现在 我 们 生活 的 所 有 角落 。 例 如 你 加 班 2.75 小 时 ， 而 公司 按 正常 工作 时 间 的 1.5 倍 支 
付 你 工资 , 你 用 这 些 钱 买 了 半 盒 鸡蛋 并 交 了 8.25% 的 销售 税 。 就算 你 不 是 数字 研究 方面 的 
专家 ， 也 可 能 对 这 种 “数字 生活 ”非常 熟悉 。 我 们 还 经 常 听 到 类 似 这 样 的 统计 信息 “ 美 
国 每 个 家 庭 的 平均 入 口 是 2.6 人 ”， 但 谁 也 不 会 为 了 满足 这 个 数字 表达 的 真实 含义 而 把 人 
拆 解 掉 〈 这 种 事情 想起 来 都 觉得 恐怖 )。 


在 计算 机 存储 器 中 ， 整 数 和 分 数 之 间 的 转换 并 不 是 这 么 随意 。 现 在 我 们 应 该 浓 楚 ， 
计算 机 中 的 一 切 数据 都 是 以 位 的 形式 存储 的 ， 这 就 意味 着 所 有 的 数 都 表示 为 二 进 制 形式 。 
但 另 一 个 不 可 否认 的 事实 是 ， 某 些 类 型 的 数 比 其 他 类 型 更 容易 用 位 的 形式 来 表示 。 


我 们 将 从 整数 的 二 进 制 表示 开始 , 这 里 的 整数 被 数学 家 称 做 “自然 数 ”( positive whole 
numbers )， 即 计算 机 程序 员 口 中 的 “ 正 整 数 ”( positive integers )， 之 后 将 介绍 如 何 利用 2 
的 补 数 来 表示 “人 负 整 数 ”( negative integers )， 该 方法 可 以 让 正 数 和 负数 的 相 加 变 得 非常 简 
单 。 下 面 的 表格 列 出 了 8 位 、16 位 、32 位 二 进 制 数 所 能 表示 的 正 整 数 及 其 2 的 补 数 的 范 
围 。 


一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
| 


数 的 位 数 正 整数 的 范围 


05 
0~65,535 32,768 ~ 32,767 

我 们 所 要 介绍 的 整数 部 分 就 是 这 些 。 除 此 之 外 ， 数 学 家 还 定义 了 用 两 个 整数 的 比值 
表示 的 一 类 数 ， 称 做 有 理 数 (rational number ) 或 分 数 (fraction )。 例 如 ，3/4 是 一 个 有 理 


数 ， 因 为 它 是 整数 3 和 4 的 比 。 我 们 也 可 以 把 3/4 表示 成 十 进 制 小 数 的 形式 ， 即 0.75。 尽 
管 我 们 可 以 把 它 写成 十 进 制 数 的 形式 ， 但 它 实际 上 代表 一 个 分 数 ， 即 75/100。 


如 第 7 章 所 述 ， 在 十 进 制 数字 系统 中 ， 小 数 点 左边 的 数 的 每 一 位 都 和 10 的 正 整数 次 
寡 相 关 , 而 其 右边 的 数 的 每 一 位 都 和 10 的 负 整数 次 宕 相关 。 我 们 在 第 7 章 用 到 了 42705.684 
这 个 实例 ， 现 在 ， 我 们 把 它 表 示 为 以 下 等 价 形式 : 


4x 10000 十 
2 x 1000+ 
7x100+ 
Ox10+ 
Sx 1 二 

6 10 十 

8 二 100+ 
4= 1000 


上 面 的 除 号 表达 了 该 位 置 的 数 与 10 的 负 整 数 次 短 相 关 的 情况 ， 用 下 面 的 表达 方式 可 以 不 
用 除 号 : 


4 x 10000+ 
2 x 1000+ 
7x100+ 
0 x 10 十 
Sxi1+ 
6x0.1+ 
8 x 0.01+ 
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4 x 0.001 

最 后 ,我 们 将 该 数 表示 为 10 的 寄 的 形式 : 
4x104+ 
2x103 + 
7x10?+ 
Ox10!+ 
5x10° + 
6X10-1 二 
8x10 一 二 
4x103 


有 一 些 有 理 数 很 难 表示 成 小 数 ， 最 明显 的 一 个 例子 是 3， 如 果 用 3 来 除 1， 会 得 到 
这 样 的 结果 : 


0.3333333333333333333333333333333333333333333333333333333333... 


在 小 数 点 的 后 面 将 会 有 无 数 个 3。 通 过 在 第 一 个 3 的 上 面 加 一 条 短 横 线 , 可 以 将 这 个 无 限 
循环 的 数 简单 表示 为 : 


03 


尽管 如 此 ,把 1/3 表示 为 小 数 还 不 是 很 方便 ,但 它 毕竟 是 一 个 有 理 数 ， 因 为 在 本 质 上 
它 是 两 个 整数 的 比 。 类 似 的 ，1/7 可 以 表示 为 : 


0.1428571428571428571428571428S71428571428571428571428571... 


渤 


0.142857 


无 理 数 (irrational number ) 是 一 些 更 加 奇特 的 数 ， 如 2 的 平方 根 等 。 它 们 不 能 表示 为 
两 个 整数 的 比 ， 这 就 意味 着 其 小 数 部 分 是 无 穷 的 ， 而 且 毫 无 规律 ， 没 有 循环 ， 例 如 ; 


V2 =1.41421356237309504880168872420969807856967187537695.... 


下 面 这 个 数学 方程 式 的 正 数 解 就 是 2 的 平方 根 : 
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编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


x —2=0 
如 果 某 个 数 不 是 任何 以 整数 为 系数 的 代数 方程 的 解 ， 那 么 这 个 数 称 做 超越 数 
(transcendental, 所 有 的 超越 数 都 是 无 理 数 , 但 是 反之 不 成 立 )。z 就 是 一 个 典型 的 超越 数 ， 
它 是 圆 的 周 长 与 其 直径 的 比值 ， 可 以 近似 的 表示 为 : 
3.141592653589793284626433832795028841971 69399375 11... 
e 是 男 一 个 典型 的 超越 数 ， 它 是 数学 表达 式 : 
az 
n 
当 n 趋向 无 穷 大 时 的 值 ， 近 似 的 值 为 : 
2.71828182845904523536028747135266249775724709369996... 
目前 我 们 所 讨论 过 的 所 有 数 一 一 有 理 数 和 无 理 数 一 一 统称 为 实数 (real numbers )。 使 
用 实数 定义 它们 的 目的 是 为 了 将 其 与 虚数 (imaginary numbers ) 区 别 开 来 ,虚数 是 负数 的 
平方 根 。 实 数 和 虚数 一 起 构成 了 复数 ( complex numbers )。 不 管 名 称 如 何 ， 它 们 都 有 重要 


的 作用 ， 例 如 ， 虚 数 确实 存在 于 现实 世界 ， 它 在 解决 电子 学 的 某 些 高 级 问题 中 有 重要 应 
用 。 


我 们 习惯 于 把 数字 看 做 连续 (contimuous ) 的 ， 任 意 给 出 两 个 有 理 数 ， 都 可 以 找 出 一 
个 位 于 它们 之 间 的 数 。 实 际 上 ， 只 需要 取 这 两 个 数 的 平均 值 即 可 。 但 是 ， 数字 计算 机 对 
连续 数据 却 无 能 为 力 ， 因 为 二 进 制 中 的 每 一 位 非 0 即 1， 两 者 之 间 没 有 任何 数 。 这 一 特点 
决定 了 数字 计算 机 只 能 处 理 离散 (discrete ) 数据 。 二 进 制 数 的 位 数 直接 决定 了 所 能 表示 
的 离散 数值 的 个 数 。 例 如 ， 如 果 你 选择 的 二 进 制 位 数 是 32， 则 所 能 表示 的 自然 数 的 范围 
是 0~4,294,967,295。 如 果 想 要 在 计算 机 中 存储 4.5 这 个 数 ， 则 需要 选择 新 的 方法 并 做 一 
些 其 他 方面 的 改进 。 


小 数 也 可 以 表示 为 二 进 制 数 吗 ? 当然 可 以 ， 最 简单 的 方法 可 能 就 是 使 用 BCD 码 〈 二 
进 制 编码 的 十 进 制 数 )。 如 第 19 章 所 述 ， BCD 码 是 将 十 进 制 数 以 二 进 制 的 形式 进行 编码 ， 
0~9 之 间 的 每 一 个 数 都 需要 用 4 位 来 表示 ， 如 下 表 所 示 。 
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十 进 制 数字 BCD 代码 
0 0000 
1 0001 
0010 | 


0011 
0100 
0101 
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BCD 编码 在 程序 处 理 用 美元 和 美 分 表示 的 钱 款 、 账 户 时 特别 有 用 。 银 行 和 保险 公司 
是 非常 典型 的 两 类 整 日 与 钱 打交道 的 机 构 ， 这 些 机 构 所 使 用 的 计算 机 程序 中 ， 大 多 数 小 
数 所 占用 的 存储 空间 仅仅 相当 于 两 个 十 进 制 数 所 占用 的 位 数 。 


通常 把 两 个 BCD 数字 存放 在 一 个 字 节 ， 这 种 方式 称 为 压缩 BCD ( packed BCD )。 日 
于 2 的 补 数 不 和 BCD 数 一 起 使 用 ， 因 此 压缩 BCD 通常 需要 增加 1 位 用 来 标识 数 的 正 负 ， 
该 位 被 称 做 符号 位 ( sign bit )。 用 一 整个 字 节 保存 某 个 特定 的 BCD 数 是 很 方便 的 ， 但 要 
为 这 个 短小 的 符号 位 牺 性 4 位 或 8 位 的 存储 空间 。 


让 我 们 来 看 一 个 例子 ,假设 计算 机 程序 所 要 处 理 的 钱 款 数 上 自在 +/-100 万 美元 之 间 ， 
这 就 意味 着 ,需要 表示 的 钱 的 数目 的 范围 是 -9,999,999.99~99,999,999.99 ， 因 此 保存 在 存 
储 器 中 的 每 一 笔 钱 的 金额 都 需要 5 个 字 节 。 因此 , 一 4,325,120.25 可 以 表示 为 下 面 5 个 字 节 : 


LH 


00010100 00110010 01010001 00100000 00100101 


将 每 个 字 节 转换 成 十 六 进 制 数 ， 上面 的 数 可 以 等 价 地 表示 成 : 


14h 32h 51h 20h 25h 

注意 ， 最 左边 的 半 个 字 节 所 构成 的 1 用 来 指明 该 数 是 负数 ， 这 个 1 即 符号 位 。 如 果 
这 半 个 字 节 所 构成 的 数 是 0， 则 说 明 该 数 是正 数 。 组 成 该 数 的 每 一 个 数字 都 需要 用 4 位 来 
表示 ， 从 十 六 进 制 的 表示 形式 中 可 以 很 直观 地 看 到 这 一 点 。 


如 果 要 表示 的 数 的 范围 扩大 到 -99 ,999,999.99~99 ,999,999.99 ， 则 我 们 需要 用 6 个 字 
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-一 六 编码 一 一 隐 芽 在 计算 机 软 硬 件 背后 的 语言 


es = 


节 来 实现 ， 其 中 5 个 字 节 用 来 表示 10 个 数字 ， 另 一 个 字 节 整个 用 来 做 符号 位 。 


这 种 基于 二 进 制 的 存储 和 标记 方式 也 被 称 作 定点 格式 ( fixed-point format ), 所 谓 的 “ 定 
点 ”是 指 小 数 点 的 位 置 总 是 在 数 的 某 个 特定 位 置 一 一 在 本 例 中 , 它 位 于 两 位 小 数 之 前 。 值 
得 注意 的 是 ， 有 关 小 数 点 位 置 的 计数 信息 并 没有 与 整个 数字 一 起 存储 。 所 以 ， 使 用 定点 
小 数 的 程序 必须 知道 小 数 点 的 位 置 。 你 可 以 设计 有 任意 小 数位 的 定点 小 数 ， 并 且 可 以 在 
程序 中 混合 使 用 它们 ， 但 程序 中 对 这 些 数 进行 算术 运算 的 部 分 都 需要 知道 小 数 点 的 位 置 ， 
这 样 才能 正确 地 对 其 做 各 种 运算 处 理 。 


如 果 可 以 确定 程序 用 到 的 数字 不 会 大 到 超过 预定 的 存储 空间 ， 并 且 这 些 数 的 小 数位 
不 会 很 多 ， 那 么 使 用 定点 格式 的 小 数 将 是 一 个 很 好 的 选择 。 在 表示 非常 大 或 非常 小 的 数 
时 ， 使 用 定点 格式 数 是 绝对 不 合适 的 。 假 设 需要 保留 一 块 内 存 空间 用 来 存放 以 英尺 为 单 
位 的 距离 数据 ， 可 能 存在 的 问题 是 某 些 距 离 的 长 度 可 能 超出 范围 。 地 球 与 太阳 之 间 的 距 
离 是 490,000,000,000 英尺 ,而 氢 原 子 的 半径 只 有 0.000,000,000,26 英尺 ,如果 采用 定点 格 
式 的 存储 方案 ,为 了 存储 这 些 极 大 或 极 小 的 数 需 要 12 个 字 节 。 


小 


科学 家 和 工程 师 们 喜欢 使 用 一 种 称 为 “科学 计数 法 ”( scientific notation ) 的 方法 来 记 
录 这 类 较 大 或 较 小 的 数 ， 利 用 这 种 计数 系统 可 以 更 好 地 在 计算 机 中 存储 这 些 数 。 科 学 计 
数 法 把 每 个 数 表示 成 有 效 位 与 10 的 寡 的 乘积 的 形式 ， 这 样 就 可 以 避免 写 一 长 串 的 0， 因 
此 这 种 计数 方式 特别 适合 表示 极 大 或 极 小 的 数 。 采 用 科学 计数 法 ， 下 面 这 个 数 ; 


490,000,000,000 
可 以 记 为 : 
4.9x10!! 
而 
0.00000000026 
可 以 表示 为 : 
2.6x1070 


在 上 面 的 两 个 例子 中 ，4.9 和 2.6 被 称 做 小 数 部 分 或 者 首 数 (characteristic )， 有 时 候 
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也 被 称 作 尾数 〔 mantissa， 这 个 词 通常 与 对 数 运算 一 起 使 用 )。 在 计算 机 术语 中 这 一 部 分 
被 称 做 有 效 数 ( significand ), 因此 为 了 保持 一致， 这 里 把 科学 计数 法 表示 形式 中 的 这 一 部 
分 也 称 作 有 效 数 。 
采用 科学 计数 法 表示 的 数 可 以 分 为 两 部 分 ， 其 中 指数 ( exponent ) 部 分 用 来 表示 10 
的 几 次 寡 。 在 第 一 个 例子 中 ， 指 数 是 11， 第 二 个 例子 中 指数 是 一 10。 指 数 可 以 表明 小 数 
点 相对 于 有 效 数 移动 的 距离 。 

为 了 便于 操作 ， 一 般 规定 有 效 数 的 取 值 范围 是 大 于 或 等 于 1 而 小 于 10。 尽 管 下 面 列 
出 的 各 种 写法 表示 的 都 是 同一 个 数 : 


4.9x10' =49x10' =490x10” =0.49x102 =0.049x105 


但 是 上 面 等 式 中 的 第 一 种 写法 是 最 恰当 的 。 这 种 写法 有 时 被 称 做 科学 计数 法 的 规范 化 式 


(normalized )。 


这 里 需要 说 明 ， 指 数 的 正 负 性 只 是 表明 了 数 的 大 小 ， 它 并 不 能 指明 数 本 身 的 正 负 性 。 
下 面 列 出 两 个 负数 的 科学 计数 法 表示 形式 : 


3 


—5.8125x107 
与 -58,125,000 相等 。 页 
—5.8125x107™ 
则 与 
—0.000,000,058,125 
相等 。 


在 计算 机 中 ， 对 于 小 数 的 存储 方式 ， 除 了 定点 格式 外 还 有 另外 一 种 选择 ， 它 被 称 做 
浮 点 格式 ( floating-point notation )。 因 为 浮 点 格式 是 基于 科学 计数 法 的 ， 所 以 它 是 存储 极 
大 或 极 小 数 的 理想 方式 。 但 计算 机 中 的 泽 点 格式 是 借助 二 进 制 数 实现 的 科学 计数 法 形式 ， 
因此 我 们 首先 要 了 解 如 何 用 一 进 制 表示 小 数 。 


实际 操作 起 来 比 预想 的 要 简单 。 在 十 进 制 数 中 ， 人 小 数 点 右边 的 数字 与 10 的 负 整数 次 
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下 编码 一 隐匿 在 计算 机 软 硬 件 背 后 的 语言 


窜 相 关联 ; 而 在 二 进 制 数 中 ,二进制 小 数 点 (就 是 一 个 简单 的 句点 ， 看 起 来 同 十 进 制 小 
数 点 一 样 ) 右边 的 数字 和 2 的 负 整数 次 宕 相关 。 例 如 ， 下 面 这 个 二 进 制 数 : 


101.1101 


可 以 用 如 下 方式 转换 为 十 进 制 数 : 


lx4+ 
0x2+ 
1x1 十 
1 全 2 十 
l=4+ 
0=8+ 
1=16 


将 乘 数 和 除数 用 2 的 整数 次 寡 蔡 换 ， 就 可 以 替换 除 号 : 


1x22+ 
Ox2!+ 
1x2°+ 
1x2-1 + 
1x23+ 
0x23+ 


1x24 


2 的 负 整数 次 宪 等 于 从 1 开始 反复 除 以 2， 上 式 可 以 改写 为 : 
1x4+ 
Ox2+ 
TXT 十 
1x0.5+ 
1x0.25 十 
0x0.125+ 
1x0.0625 


经 过 这 种 计算 ，101.1101 与 十 进 制 数 5.8125 是 相等 的 。 
在 十 进 制 的 科学 计数 法 中 , 规范 化 式 的 有 效 数 应 该 大 于 或 等 于 1 且 小 于 10; 类 似 的 ， 
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在 二 进 制 的 科学 计数 法 中 ， 规 范 化 式 的 有 效 数 应 该 大 于 或 等 于 1 且 小 于 10( 即 十 进 制 的 
2)。 因 此 ， 在 二 进 制 的 科学 计数 法 中 ， 下 面 这 个 数字 : 


101.1101 
其 规范 化 式 应 该 是 : 
1.011101x22 


这 个 规则 暗示 了 这 样 一 个 有 趣 的 现象 : 在 规范 化 二 进 制 浮 点 数 中 ， 小 数 点 的 左边 通常 
有 一 个 1， 除 此 之 外 没有 其 他 数字 。 


当代 大 部 分 计算 机 和 计算 机 程序 在 处 理 浮 点 数 时 所 遵循 的 标准 是 由 IEEE( Institute of 
Electrical and Electronies Engineers, 美国 电气 和 电子 工程 师 协会 ) 于 1985 年 制定 的 , ANSI 
(American National Standards Institute， 美 国 国家 标准 局 ) 也 认可 该 标准 。ANSUIEEE Std 
754-1985 称 作 IEEE 二 进 制 浮 点 数 算术 运算 标准 (IEEE Standard for Binary Floating-Point 
Arithmetic ) 一 一 它 只 有 18 页 一 一 相对 于 其 他 标准 来 说 是 非常 简短 了 ,但 却 奠定 了 以 简 f 
方式 编码 二 进 制 浮 点 数 的 基石 。 


IEEE 浮 点 数 标 准 定义 了 两 种 基本 的 格式 : 以 4 个 字 节 表示 的 单 精度 格式 和 以 8 个 字 
节 表 示 的 双 精 度 格 式 。 


让 我 们 首先 来 了 解 一 下 单 精度 格式 。 它 的 4 个 字 节 可 以 分 为 三 个 部 分 ; 1 位 的 符号 位 
(0 代表 正 数 ，1 代表 负数 )，8 位 用 做 指数 ， 最 后 的 23 位 用 做 有 效 数 。 下 表 给 出 了 单 精度 
格式 的 三 部 分 的 划分 方式 ， 其 中 有 效 数 的 最 低位 在 最 右边 。 
s= 1 位 符号 | e= 8 位 指数 | /= 23 位 有 效 数 | 

三 部 分 共 32 位 ， 也 就 是 4 个 字 节 。 我 们 刚才 提 到 过 ， 对 于 二 进 制 科 学 计数 法 的 规范 
化 式 ， 其 有 效 数 的 小 数 点 无 边 有 是 仅 有 一 个 1， 因 此 在 IEBE 浮 点 数 标准 中 ， 这 一 位 没有 
分 配 存储 空间 。 在 该 标准 中 ， 仅 存储 有 效 数 的 23 位 小 数 部 分 ， 尽管 存 储 的 只 有 23 位 ， 
但 仍然 称 其 精度 为 24 位 。 我 们 将 在 下 面 的 内 容 里 体会 24 位 精度 的 含义 。 

8 位 指数 部 分 的 取 值 范围 是 0~ 255， 称 为 偏 移 ( biased ) 指数 ， 它 的 意思 是 : 对 于 有 
符号 指数 ， 为 了 确定 其 实际 所 代表 的 值 必须 从 指数 中 减 去 量 (bias )。 
对 于 单 精度 浮 点 数 ， 其 偏 移 量 为 127。 


| 


/ 


~ 
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指数 0 和 255 用 于 特殊 的 目的 ， 稍 后 将 简单 介绍 。 如 果 指 数 的 取 值 范围 是 1~ 254， 
那么 对 于 一 个 特定 的 数 ， 可 以 用 (符号 位 )，e (指数 ) 以 及 f (有效 数 ) 来 描述 它 : 


(xl1.Ax2227 
-1 的 s 次 宕 是 数学 上 所 采用 的 一 种 巧妙 的 方法 ， 它 的 含义 是 ， 如 果 s = 0， 则 该 数 是 
正 的 (因为 任何 数 的 0 次 寡 都 是 1 ); 如 果 s = 1, 则 该 数 是 负 的 ( 因为 -1 的 1 次 窜 等 于 -1 )。 


表达 式 的 中 间 部 分 是 1./ ,其 含义 是 : 1 的 后 面 是 小 数 点 , 小 数 点 后 面 跟着 23 位 的 有 
效 数 。1.f 与 2 的 寡 相 乘 ， 其 中 指数 等 于 内 存 中 的 8 位 的 偏 移 指 数 减 去 127。 


注意 ， 目 前 为 止 我 们 还 没有 学 习 如 何 表达 那个 经 常 遇 到 却 义 总 被 遗忘 的 一 个 数字 : 
那 就 是 “0”。 这 是 一 种 特殊 的 情况 ， 下 面 我 们 对 其 进行 说 明 。 
s 如 果 e = 0 且 f= 0， 则 该 数 为 0。 在 这 种 情况 下 ， 通 常 把 32 位 都 设置 为 0 以 表示 
该 数 为 0。 但 是 符号 位 可 以 设置 为 1， 这 种 数 可 以 解释 为 负 0。 负 0 可 以 用 来 表示 
非常 小 的 数 ， 这 些 数 极 小 以 至 于 不 能 在 单 精度 格式 下 用 数字 和 指数 来 表示 ， 但 它 
们 仍然 小 于 0。 
* 如 果 e=0 且 0， 则 该 数 是 合法 的 ， 但 不 是 规范 化 的 。 这 类 数 可 以 表示 为 : 


(—1) x0.f x27 

注意 ， 在 有 效 数 中 ， 小 数 点 的 左边 是 0。 
s 如 果 e = 255 旦 f= 0， 则 该 数 被 解释 为 无 穷 大 或 无 穷 小 ， 这 取决 于 符号 位 s 的 值 。 
s 如 果 e= 255 目 f 二 0， 则 该 值 被 解释 为 “不 是 一 个 数 ”， 通 常 被 缩写 为 NaN (nota 
number )。NaN 用 来 表示 未 知 的 数 或 非法 操作 的 结果 。 


单 精度 浮 点 格式 下 ， 可 以 表示 的 规格 化 的 最 小 正 、 负 二 进 制 数 是 : 


1.000000000000000000000002x 271* 


小 数 点 后 面 跟着 23 个 二 进 制 0。 单 精度 浮 点 格式 下 ， 可 以 表示 的 规格 化 的 最 大 正 、 
负 二 进 制 数 是 : 


LA11111111111111111111112x2'7 


在 十 进 制 下 , 这 两 个 数 近 似 地 等 于 1.175494351x10-38 和 3.402823466x10*, 这 也 就 是 


和 m. 374 


23 ”定点 数 和 浮 点 数 了 一 
Te | 


单 精度 浮 点 数 的 有 效 表示 范围 。 


如 前 所 述 ，10 位 二 进 制 数 可 以 近似 地 用 3 位 十 进 制 数 来 表示 。 其 含义 是 ， 如 果 把 10 
位 都 置 为 1， 即 十 六 进 制 的 3FFh 或 十 进 制 的 1023， 它 近似 等 于 把 十 进 制 数 的 3 位 都 置 为 
9， 即 999， 可 以 表示 为 下 面 的 约 等 式 : 


210 > 103 
两 者 之 间 的 这 种 关系 意味 着 : 单 精 度 浮 点 数 格式 存放 的 24 位 二 进 制 数 大 体 上 与 7 位 


的 十 进 制 数 相等 。 因 此 ， 可 以 说 单 精 度 浮 点 格式 提供 24 位 的 二 进 制 精度 或 者 7 位 的 十 进 
制 精度 。 其 深层 的 含义 是 什么 呢 ? 


当 我 们 查看 定点 数 时 ， 其 精确 度 是 很 明显 的 。 例 如 ， 当 我 们 表示 钱 款 时 ， 采 用 两 位 
定点 小 数 就 可 以 精确 到 美 分 。 但 是 对 于 采用 浮 点 格式 的 数 ， 就 不 能 如 此 肯定 了 。 其 精确 
度 依赖 于 指数 的 值 ， 有 时 候 浮 点 数 可 以 精确 到 比美 分 还 小 的 单位 ， 但 有 时 候 其 精确 度 其 
至 达 不 到 美元 。 


这 样 说 可 能 更 合适 : 单 精度 浮 点 数 的 精度 为 1/12* ,或 M16777216， 或 百 万 分 之 六 ， 
但 其 真正 的 含义 是 什么 呢 ? 


首先 ， 这 意味 着 在 单 精度 浮 点 格式 下 ，16,777,216 和 16,777,217 将 表示 成 同一 个 数 。 
不 仅 如 此 ， 处 于 这 两 个 数 之 间 的 所 有 的 数 (例如 ，16,777,216.5 ) 也 将 被 表示 成 同一 个 数 。 
所 以 上 面 提 到 的 3 个 十 进 制 数 都 按 32 位 单 精度 浮 点 数 : 


4B800000h 


来 存放 。 将 该 数 按 符号 位 、 指 数位 和 有 效 数位 划分 ， 可 以 表示 为 : 


0 10010111 00000000000000000000000 


1.00000000000000000000000, x 2” 


下 一 个 二 进 制 浮 点 数 可 表示 的 最 大 有 效 数 是 16,777,218， 即 : 


1.00000000000000000000001, x 2* 
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一 下 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


以 同一 个 浮 点 数 来 表示 两 个 不 同 的 十 进 制 数 ， 有 时 可 能 成 为 一 个 问题 ， 也 可 能 不 会 。 


但 如 果 你 为 银行 编写 程序 ， 用 单 精度 浮 点 数 来 存放 以 美元 、 美 分 为 单位 的 数字 时 ， 
就 会 发 现 262144.00 美元 和 262144.01 美元 在 计算 机 中 存储 为 同一 个 数 : 
1.00000000000000000000000, x22 


这 也 是 为 什么 人 们 在 处 理 以 美元 、 美 分 表示 的 钱 款 数 目 时 更 愿意 使 用 定点 数 的 一 个 原因 。 
当 使 用 浮 点 数 时 ， 你 会 发 现 它 还 存在 着 一 些 让 人 前 溃 的 小 问题 。 你 的 程序 进行 了 一 系列 
计算 ,应 该 得 到 的 结果 为 3.50 的 , 但 由 于 使 用 浮 点 数 ， 你 得 到 的 可 能 是 3.499999999999。 
这 种 问题 在 评点 数 运算 中 经 常 发 生 ， 而 且 没 有 一 套 完 整 的 解决 方案 。 

如 果 想 在 程序 中 使 用 祥 点 格式 数 ， 但 使 用 单 精 度 格 式 又 会 出 现 各 种 问题 ， 这 时 你 可 
以 考虑 使 用 双 精 度 浮 点 数 ( double-precision floating-point format )。 这 种 类 型 的 数 需要 用 8 
个 字 节 来 表示 ， 它 的 结构 如 下 表 所 示 。 

[s=1 位 符号 位 ”| e= 11 位 指数 位 | /=52 位 有 效 数 | 

双 精 度 浮 点 数 的 指数 偏 移 量 是 1023, 或 十 六 进 制 的 3FFh， 因 此 以 该 格式 存储 的 数 可 

以 表示 为 : 


(六 x1.f x27 


上 面 提 到 的 关于 单 精度 浮 点 格式 下 的 0， 无穷 大 (小 ) 和 NaN 的 判断 规则 同样 适用 
于 双 精 度 浮 点 格式 。 


双 精 度 浮 点 格式 下 可 以 表示 的 最 小 正 数 或 负数 为 : 


1.00000000000000000000000000000000000000000000000000002 x2-10 


注意 ， 小 数 点 的 后 面 共有 52 个 0。 同 样 的 ， 可 以 表示 的 最 大 数 为 : 


LIL1i1i11111II1IILLLILI1LILLILI1I1I1I1111I1I1II1ILI1I1I1111111112 x21023 
其 所 能 表示 的 范围 ， 用 十 进 制 可 以 近似 记 为 : 
2.2250738585072014x103%~1.7976931348623158x10% 


10 的 308 次 寡 是 一 个 非常 巨大 的 数 , 在 1 的 后 面 跟着 308 个 0。 
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双 精 度 浮 点 格式 的 有 效 数 有 53 位 〈 包 括 前 面 没 有 列 出 的 那 一 位 )， 大 致 相当 于 十 进 
制 的 16 位 。 与 单 精度 浮 点 格式 相 比 ， 这 已 经 有 了 很 大 的 改进 了 ， 但 仍然 不 能 避免 两 个 不 
同 的 数 存储 为 同一 个 结果 的 情况 。 例 如 ,140,737,488,355,328.00 和 140,737,488,355,328.01 
在 内 存 中 存放 时 ， 会 被 当做 同一 个 数 来 处 理 ， 它 们 的 双 精 度 浮 点 格式 表示 为 : 


42E0000000000000h 
即 : 
1.00000000000000000000000000000000000000000000000000002 x2” 

当然 ,为 浮 点 数 发 明 一 种 在 内 存 中 的 存储 方式 ， 这 只 是 在 汇编 程序 使 用 祥 点 数 所 涉 
及 的 工作 的 一 小 部 分 。 如 果 你 决定 闭门造车 ， 完 全 独立 地 开发 一 台 计 算 机 ， 则 必须 要 独 
立 编 写 用 于 浮 点 数 加 、 减 、 乘 、 除 运算 的 函数 集 。 笠 运 的 是 ， 有 了 前 面 关 于 整数 四 则 运 
算 的 学 习 ， 这 些 关于 宰 点 数 的 运算 就 可 以 分 解 成 许多 小 的 关于 整数 的 加 、 减 、 乘 、 除 运 
算 ， 这 样 就 能 将 问题 大 大 简化 。 


例如 ， 浮 点 数 加 法 中 最 重要 一 点 的 就 是 如 何 对 有 效 数 相 加 ， 为 了 能 使 它们 的 有 效 位 
匹配 ， 需 要 利用 指数 来 确定 对 其 如 何 移 位 。 假 设 要 进行 下 面 的 加 法 运算 : 
(1.1101x25)+ (1.0010x 27) 


你 需要 把 有 效 数 部 分 的 11101 和 10010 相 加 , 但 并 不 是 简单 地 直接 相 加 。 两 个 数 的 指 
数 部 分 的 不 同 决定 了 第 二 个 数 必须 相对 于 第 一 个 数 右 移 。 实 际 上 我 们 要 做 的 整数 加 法 应 
该 是 11101000 加 10010。 最 后 的 运算 结果 是 : 


1.1111010x2 


前 面 我 们 曾 列 出 过 太阴 与 地 球 的 距离 以 及 氢 原 子 的 半径 ， 如 果 把 这 两 个 数 相 加 会 是 
怎样 的 结果 了 呢 ? 显而易见 ， 因 为 它们 两 者 的 指数 相差 太 大 ， 因 此 较 小 的 数 对 结果 甚至 没 
有 影响 。 

两 个 浮 点 数 的 乘法 意味 着 要 把 有 效 数 当 作 整数 相 乘 ， 并 且 把 指数 部 分 相 加 。 为 了 使 
结果 规范 化 ， 一 般 需 要 对 指数 调整 一 到 两 次 。 


浮 点 数 运算 另 一 层次 的 复杂 性 体现 在 处 理 一 些 较为 繁杂 的 函数 运算 ， 例 如 平方 根 、 
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指数 、 对 数 和 三 角 函 数 。 但 所 有 的 这 些 运算 都 可 以 通过 加 、 减 、 乘 、 除 这 四 种 基本 的 浮 
点 数 运算 来 实现 。 


例如 ， 三 角 函 数 中 的 sin 函数 可 以 通过 下 面 的 一 系列 展开 式 近似 计算 : 


参数 x 的 值 必须 是 弧度 ，360。 对 应 的 弧度 范围 是 2x。 上 式 中 的 感到 号 表示 阶乘 运算 
符 ， 它 的 意义 是 把 从 1 到 该 数 之 间 的 所 有 整数 相 乘 ， 例 如 5!=1x2x3x4x5 。 这 只 是 简单 
的 乘法 运算 ， 每 一 项 的 指数 部 分 也 是 乘法 运算 。 其 余 的 部 分 也 只 是 简单 的 除法 ， 加 法 或 
减法 运算 ,这些 都 是 容易 实现 的 。 上 面 的 算式 中 ,唯一 让 人 感到 来 手 的 地 方 是 最 后 的 省 
略 部 分 ， 这 意味 着 计算 会 一 直 继 续 下 去 。 然 而 事情 并 没有 想象 中 的 那么 粳 糕 ， 在 实际 运 
算 中 ， 如 果 把 弧度 的 取 值 限制 在 0~m/2 的 范围 内 ( 从 这 个 范围 就 可 以 推导 出 所 有 的 正弦 
值 )， 你 根本 不 需要 进行 多 少 运算 ， 因 为 大 约 展开 12 项 后 ,就 可 以 使 结果 精确 到 双 精 度 
浮 点 数 要 求 的 53 位 。 


当然 ， 使 用 计算 机 的 目的 就 是 帮助 人 们 更 加 方便 地 解决 问题 ， 而 编写 程序 来 进行 浮 
点 数 运算 这 一 繁杂 工作 似乎 和 这 个 目的 背道而驰 。 但 这 正 是 软件 的 优势 所 在 ; 一 且 某 个 
人 为 特定 的 计算 机 编写 了 浮 点 数 运 算 的 程序 ， 那 么 其 他 的 人 都 可 以 使 用 它 。 浮 点 数 运算 
在 科学 和 工程 类 程序 中 极为 重要 ， 因 此 常常 被 荆 耶 很 高 的 优先 级 。 在 计算 机 发 展 的 早期 ， 
为 新 制造 的 计算 机 做 的 第 一 项 工作 就 是 为 其 编写 浮 点 数 运算 程序 。 


实际 上 ， 其 至 可 以 直接 利用 计算 机 机 器 码 指 令 来 实现 浮 点 数 的 运算 。 当 然 ， 实 际 做 
起 来 要 比 “ 动 动 嘴 皮子 ”困难 得 多 ,但 这 也 从 另 一 个 方面 说 明了 浮 点 数 运算 的 重要 性 。 
如 果 可 以 在 硬件 上 实现 浮 点 数 算术 运算 一 一 类 似 在 16 位 微 处 理 器 上 进行 乘法 和 除法 运 
算 一 一 则 该 机 器 上 的 所 有 的 浮 点 数 运算 都 会 变 得 更 快 。 

IBM 公司 在 1954 年 发 布 了 IBM 704， 它 是 第 一 台 将 浮 点 数 运算 硬件 作为 可 选 配 件 的 
商用 计算 机 ， 该 机 器 以 36 位 空间 来 存储 所 有 的 数 。 对 于 浮 点 数 而 言 ， 其 36 位 被 分 成 27 
位 的 有 效 数 ，8 位 的 指数 和 1 位 的 符号 位 。 浮 点 运算 硬件 可 以 直接 进行 加 法 、 减 法 、 乘 法 
和 除法 运算 。 其 他 的 浮 点 运算 则 必须 通过 软件 来 实现 。 


从 1980 年 开始 ， 浮 点 运算 硬件 开始 应 用 于 桌面 计算 机 ， 这 起 始 于 英特尔 当年 发 布 的 
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8087 数字 协同 处 理 (Numeric Data Coprocessor ) 芯片 ， 当 时 这 种 集成 电路 被 称 做 数学 协 
同 处 理 器 (math coprocessor ) 或 浮 点 运算 单元 ( floating-point unit，FPU )。8087 不 能 独立 
工作 ， 它 只 能 与 8086 或 8088 ( Intel 的 首 个 16 位 微 处 理 器 ) 芯片 一 起 工作 ， 因 此 被 称 做 
协 处 理 器 。 


8087 拥有 40 个 管 脚 ， 它 使 用 的 很 多 信号 与 8086 或 8088 完全 相同 。 微 处 理 器 和 数学 
协 处 理 器 通过 这 些 信 号 相连 。 当 CPU 读 取 到 一 条 特殊 指令 ESC ( Escape ) 时 一 一 协同 处 
理 器 开始 接管 控制 权 并 执行 下 一 条 机 器 指令 ， 该 指令 可 以 是 三 角 函 数 、 指 数 和 对 数 等 68 
条 指令 中 的 任 一 条 。 它 所 处 理 的 数据 类 型 遵循 IEEE 标准 。 在 当时 ，8087 被 认为 是 市 面 上 
最 高 水 平 的 集成 电路 。 


可 以 把 协 处 理 器 当做 一 个 小 型 的 自 包 含 计 算 机 。 当 响应 某 个 特定 的 浮 点 运算 机 器 码 
指令 时 (例如 FSQRT 指令 ， 它 用 来 计算 平方 根 )， 协 处 理 器 会 以 固有 的 方式 执行 存放 在 
ROM 中 属于 自己 的 指令 序列 。 这 些 内 部 指令 称 做 微 代码 (microcode )。 通常， 这 些 指令 
都 是 循环 的 ， 因 此 不 能 立即 得 到 最 终 的 结果 。 虽 然 如 此 ， 但 数学 协 处 理 器 在 运算 速度 方 
面 仍然 表现 优异 ， 与 软件 方法 相 比 ， 其 速度 至 少 是 后 者 的 10 倍 。 


在 最 初版 本 的 IJBM PC 主板 上 ,位 于 8080 芯片 的 右边 有 1 个 40 个 管 脚 的 播 槽 供 8087 
芯片 接 入 。 但 令 人 失望 的 是 ， 这 个 插 模 是 空 的 ， 用 户 如 果 需 要 进行 浮 点 数 运算 就 必须 单 
独 购 置 一 块 8087 芯片 ， 并 将 其 搬入 主板 后 才能 使 用 。 安 装 数学 协 处 理 器 并 不 能 提高 所 有 
应 用 程序 的 运行 速度 , 因为 有 些 应 用 程序 一 一 比如 文字 处 理 程序 一 一 几乎 用 不 到 浮 点 数 运 
算 。 其 他 应 用 程序 ， 比 如 电子 表格 处 理 程序 ， 对 浮 点 数 运 算 依赖 程度 很 高 ， 在 安装 了 数 
学 协 处 理 器 之 后 ， 它 们 的 执行 速度 有 很 大 的 提高 ， 但 并 非 所 有 的 程序 都 是 如 此 。 


可 以 看 到 ， 在 安装 了 数学 协 处 理 器 后 ， 程 序 员 必须 使 用 协 处 理 器 机 器 码 指令 来 编写 
特殊 的 代码 ， 因 为 数学 协 处 理 器 不 是 标准 硬件 ， 因 此 它 只 能 执行 这 些 特 殊 的 代码 。 而 这 
些 工 作 让 程序 员 焕 不 胜 烦 。 尽 管 他 们 不 原意， 他们 仍 不 得 不 编写 自己 的 浮 点 数 运 算 子 程 
序 ( 因为 大 多 数 人 并 没有 安装 数学 协 处 理 器 ), 因此 这 就 多 了 一 个 额外 的 工作 个 并 不 
轻松 的 工作 -一 在 程序 中 支持 8087 芯片 。 最 后 就 出 现 了 这 样 的 局 面 : 如 果 机 器 上 安装 了 
数学 协 处 理 器 ， 程 序 员 就 要 学 会 编写 相应 的 应 用 程序 以 支持 它 的 运行 ;如 果 没 有 安装 ， 
程序 员 就 要 通过 编程 来 模拟 它 进行 浮 点 数 的 运算 。 


在 随后 的 几 年 内 ， 英 特 尔 还 发 布 了 与 286 配合 工作 的 287 数学 协 处 理 器 ,与 386 配 
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合 工作 的 387 数学 协 处 理 器 。 但 是 ， 在 1989 年 发 布 的 486DX 芯片 中 ，FPU 已 经 内 建 在 
CPU 的 结构 里 ， 它 不 再 作为 一 个 配件 供 选 择 安装 了 。 令 人 失望 的 是 ， 在 1991 年 发 布 的 
款 低 端 芯片 486SX 中 ,英特尔 没有 为 该 其 内 建 FPU， 而 是 提供 了 一 块 可 选 的 487SX 数学 
协 处 理 芯 片 。 但 1993 年 发 布 的 奔腾 芯片 中 ，CPU 内 置 FPU 再 次 成 为 标准 ， 也 许 这 是 永 
远 的 标准 。 在 1990 年 发 布 的 68040 芯片 中 ,摩托 罗拉 首次 将 FPU 集成 在 CPU 中 , 在 此 之 
前 ， 摩托罗拉 发 布 『 68881 和 68882 数学 协 处 理 器 来 支持 68000 家 族 早 期 的 微 处 理 器 。 
PowerPC 芯片 同样 使 用 了 内 置 浮 点 数 运算 硬件 的 技术 。 


浮 点 数 运算 硬件 对 于 困惑 的 沪 编 程序 员 来 说 无 疑 是 个 惊喜 的 礼物 ， 但 相对 于 20 世纪 
50 年 代 开始 的 某 些 其 他 工作 来 言 ， 这 只 是 历史 所 迈 出 的 一 小 步 。 接 下 来 ,我 们 的 探索 之 
旅 即将 到 达 下 一 站 : 计算 机 语言 。 
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使 用 机 器 码 编写 程序 就 如 同 用 牙签 吃 东西 ， 伸 出 手臂 使 出 较 大 的 力气 刺 向 食物 ， 但 
每 次 都 只 获取 到 小 小 的 一 块 ， 这 个 过 程 是 辛苦 且 漫 长 的 。 同 样 的 ， 每 个 机 器 码 字 节 所 能 
完成 的 工作 , 是 你 能 想象 到 的 最 微小 且 最 简单 的 工作 一 一 从 内 存 获取 一 个 数 , 之 后 加 载 到 
处 理 器 , 再 把 它 与 另 一 个 数 相 加 ， 最 终 将 运算 结果 保存 到 内 存 等 一 一 正 因 如 此 ,很 难 想象 
如 何 使 用 这 些 机 器 码 构 成 一 个 完整 的 程序 。 


目前 为 止 ， 至少 对 于 在 第 22 章 讨论 的 原始 模型 阶段 来 说 ,我 们 已 经 取得 了 一 定 的 进 
步 ， 在 那个 阶段 ,我 们 使 用 过 控制 面板 上 的 开关 将 二 进 制 数据 输入 到 存储 器 。 在 第 22 章 
中 ,介绍 了 如 何 编 写 一 段 简 单 的 程序 ， 让 我 们 可 以 利用 键盘 将 十 六 进 制 机 器 码 输入 计算 
机 ， 以 及 通过 视频 显示 设备 来 检查 这 些 代码 。 这 种 改进 固然 可 取 ， 但 仍 不 是 我 们 的 终极 
目标 。 


前 面 的 章节 介绍 过 ， 可 以 使 用 某 些 较 短 的 助 记 符 来 关联 机 器 码 字 节 ， 这 些 助 记 符 包 
括 MOV，ADD，CALL，HIT 等 ， 通 过 这 些 类 似 英语 的 符号 我 们 可 以 较 方便 地 引用 机 器 
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码 。 通 常 这 些 助 记 符 的 后 面 会 跟着 操作 数 ， 这 可 以 进一步 指明 它 所 关联 的 机 器 码 指令 的 
功能 。 例 如 8080 机 器 码 字 节 46h， 它 的 功能 是 令 处 理 器 将 存储 在 内 存 特定 地 址 的 字 节 转 
移 至 寄存 器 B， 而 该 地 址 由 寄存 器 对 HL 中 的 16 位 数 寻 址 。 这 个 操作 可 以 简单 地 写 做 ; 


MOV B, [HLI] 


显然 ， 使 用 汇编 语言 编写 程序 要 比 使 用 机 器 语言 简单 得 多 ， 但 微 处 理 器 并 不 能 解释 
汇编 语言 。 在 前 面 的 章节 中 我 们 已 经 学 习 了 如 何在 纸 上 编 写 汇 编程 序 ， 但 只 有 当 你 确实 
准备 在 微 处 理 器 上 运行 汇编 程序 ， 才 会 手工 对 其 汇编 ， 这 样 就 可 以 将 汇编 语言 程序 的 语 
名 转换 成 了 机 器 语言 代码 ， 并 把 它们 输入 内 存 。 
当然 ， 我 们 希望 最 好 由 计算 机 能 独自 完成 语言 转换 的 工作 。 如 果 你 的 8080 计算 机 正 
在 运行 CP/M 操作 系统 ,而 且 你 已 经 拥有 了 所 有 必需 的 工具 , 那 就 再 好 不 过 了 , 因为 下 面 
我 们 将 介绍 其 工作 原理 。 


第 一 步 ， 建 立 一 个 文本 文件 ， 并 将 汇编 语言 程序 输入 到 该 文本 文件 中 。 这 项 工作 可 
以 使 用 CP/M 的 应 用 程序 ED.COM 来 完成 。 该 程序 是 一 个 可 以 用 来 创建 、 修 改 文本 文件 
的 编辑 器 。 假 设 你 把 该 文本 文件 命名 为 PROGRAM1.ASM, 其 中 ASM 是 文件 类 型 ， 用 来 

站 明 该 文本 文件 的 内 容 是 由 汇编 语言 程序 组 成 。 这 个 文件 的 内 容 如 下 : 


ORG 0100h 
LXI DE, Text 
MVI C,9 
CALL 5 
RET 

Text: DB 'Hello!s$" 
END 


这 个 文件 中 有 两 条 语句 我 们 从 未 接触 过 。 第 一 条 语句 是 ORG ( origin )， 它 不 与 任何 
8080 指令 对 应 ， 其 功能 是 用 来 指明 下 面 语句 的 地 址 从 0100h 地 址 处 开始 。 如 前 所 述 ， 该 
地 址 是 CP/M 将 程序 装 入 内 存 的 起 始 地 址 。 


第 二 条 语句 是 LXI ( Load Extended Immediate ) 指令 ， 其 功能 是 将 一 个 16 位 数 加 载 
到 寄存 器 对 DE。 在 本 例 中 , 该 16 位 数 是 由 标记 Text 提供 的 。 该 标记 在 程序 底 端 的 附近 ， 
位 于 DB (Data Byte ) 语句 之 前 。DB 语句 我 们 也 是 第 一 次 遇 到 ， 其 后 可 以 跟着 一 些 字 节 ， 
这 些 字 节 以 逗号 分 隔 或 者 用 单 引号 括 起 来 (如 本 例 )。 
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MVI (Move Immediate ) 语句 将 数值 9 转移 到 寄存 器 C。CALL 5 语句 实现 CP/M 的 
函数 调用 功能 。 函 数 5 的 作用 是 : 显示 以 寄存 器 对 DE 给 出 的 地 址 为 起 始 处 的 字符 串 , 直 
到 遇 到 $ 结 束 ( 可 以 看 到 ， 在 程序 的 结尾 处 使 用 了 美元 符号 “$” 作 为 文本 的 结束 标志 ， 
这 种 方式 看 起 来 很 奇怪 , 但 CP/M 就 是 采取 的 这 种 方式 )。 最 后 的 RET 语句 用 来 结束 程序 ， 
并 把 控制 权 交还 给 CP/M 实际 上 ， 这 只 是 结束 CP/M 程序 的 方法 之 一 )。END 语句 用 来 
指明 汇编 语言 文件 已 经 结束 。 


现在 我 们 已 经 有 了 一 个 包含 7 行 语句 的 文本 文件 ， 下 一 步 要 做 的 就 是 对 其 进行 汇编 ， 
即将 其 转换 成 机 器 语言 代码 。 以 前 这 项 工作 是 通过 手工 完成 的 ， 但 现在 我 们 的 机 器 运行 
的 是 CP/M 系统 , 可 以 利用 CP/M 中 一 个 叫做 ASM.COM 的 模块 来 完成 这 项 工作 。 该 模块 
是 CP/M 的 汇编 器 ( assembler )。 可 以 在 CP/M 的 命令 行 中 使 用 下 面 的 语句 运行 ASM.COM 
文件 : 


ASM PROGRAM] .ASM 


ASM 对 PROGRAM1.ASM 文件 进行 汇编 ， 产 生 一 个 名 为 PROGRAM1.COM 的 新 文 
件 ，PROGRAM1.COM 包含 了 与 我 们 编写 的 汇编 程序 相对 应 的 机 器 码 (实际 上 ， 该 过 程 
还 包含 另 一 个 步骤 ， 但 在 该 操作 中 并 不 重要 )。 现 在 就 可 以 使 用 CP/M 的 命令 行 来 运行 
PROGRAM1.COM 文件 ， 程 序 运行 的 结果 是 显示 字符 串 “Hello!” 然 后 结束 。 


PROGRAM1.COM 文件 包含 以 下 16 个 字 节 : 


11 09 01 0E 09 CD 05 00 C9 48 65 6C 6C 6F 21 24 


开始 的 3 个 字 节 是 LXI 指令 ， 其 后 的 两 个 字 节 是 MVI 指令 ， 接 下 来 的 三 个 字 节 是 
CALL 指令 ， 紧 随 其 后 的 一 个 字 节 是 RET 指令 ， 最 后 的 7 个 字 节 是 ASCI 码 ， 包 括 5 个 
字母 “Hello”， 感 到 号 “1!1” 以 及 美元 符号 “$”。 


像 ASM.COM 这 样 的 汇编 器 程序 所 做 的 工作 是 : 读 取 一 个 汇编 语言 文件 ( source-code， 
通常 称 做 源 代码 文件 ), 将 其 转换 得 到 一 个 包含 机 器 码 的 文件 一 可 执行 文件 ( executable 
file )。 从 宏观 的 角度 来 看 , 汇编 器 是 非常 简单 的 ， 因 为 构成 汇编 语言 的 助 记 符 和 机 器 码 之 
间 是 一 一 对 应 的 。 汇 编 器 拥有 一 张 包括 所 有 可 能 助 记 符 及 其 参数 的 表 ， 它 逐 行 读 取 汇编 
语言 程序 ， 把 每 一 行 都 分 解 成 为 助 记 符 和 参数 ， 然 后 把 这 些 短小 的 单词 和 字符 与 表 中 的 
内 容 匹 配 。 通 过 这 种 匹配 的 过 程 ， 每 一 个 语句 都 会 找到 与 其 对 应 的 机 器 码 指令 。 
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注意 , 汇编 器 如 何 知道 LXI 指令 必须 将 寄存 器 DE 的 值 设置 为 地 址 0109h ( Text 的 地 
址 )。 如 果 LXI 指令 本 身 被 存放 在 地 址 0100h 处 (CP/M 将 程序 加 载 至 内 存 开始 运行 时 的 
起 始 地 址 ), 而 0109h 则 是 Text 字符 串 的 起 始 地 址 。 一 般 来 说 , 程序 员 在 使 用 汇编 器 时 有 
很 多 方便 之 处 ， 其 中 一 点 就 是 不 需要 关心 汇编 程序 各 部 分 在 内 存 中 的 存放 地 址 。 

第 一 个 编写 汇编 器 的 人 需要 手工 对 程序 汇编 。 如 果 要 为 机 器 写 一 个 新 的 汇编 器 (或 


者 对 其 修改 ) 则 可 以 使 用 汇编 语言 编写 该 程序 ， 然 后 使 用 原 有 的 汇编 器 对 其 汇编 。 一 旦 
新 的 汇编 器 通过 了 汇编 ， 则 它 也 就 可 以 对 自身 进行 汇编 。 


每 当 一 种 新 的 微 处 理 器 面世 ， 就 需要 为 其 编写 新 的 汇编 器 。 然 而 ， 新 的 汇编 器 可 以 
在 已 有 的 计算 机 上 编写 ， 并 利用 其 汇编 器 进行 汇编 。 这 种 方式 称 为 交叉 汇编 
(cross-assembler )， 即 利用 计算 机 A 的 汇编 器 对 运行 在 计算 机 B 上 的 程序 汇编 。 


虽然 汇编 器 的 引入 消除 了 汇编 语言 编程 中 重复 性 的 劳动 部 分 〈 即 手动 汇编 部 分 ), 但 
汇编 语言 仍然 存在 两 个 主要 问题 。 第 一 个 问题 (也许 你 已 经 意识 到 了 )， 使 用 汇编 语言 
程 非常 乏味 ， 因 为 这 是 在 微 处 理 器 芯片 级 的 编程 ， 因 此 不 得 不 考虑 每 一 个 微小 的 细节 。 


汇编 语言 存在 的 第 二 个 问题 是 不 可 “移植 ”(portable )。 如 果 你 为 Intel 8080 写 了 一 个 
汇编 语言 程序 , 则 该 程序 不 能 在 Motorola 6800 上 运行 , 你 必须 在 6800 上 重 写 一 个 相同 功 
能 的 汇编 语言 程序 。 编 写 类 似 程序 的 过 程 也 许 没 有 编写 第 一 个 程序 那么 困难 ， 因 为 你 应 
经 解决 了 程序 的 组 织 和 算法 问题 ， 但 仍然 还 有 很 多 工作 要 做 。 


上 一 章 介绍 了 现代 微 处 理 器 集成 浮 点 运算 机 器 码 指 令 的 原理 。 不 可 否认 ， 这 已 经 为 
我 们 带 来 了 很 大 的 便利 ， 但 仍 不 能 令 人 特别 满意 。 一 种 更 好 的 方式 是 : 完全 放弃 那些 实 
现 每 个 基本 操作 的 机 器 码 指 令 ， 这 些 指令 与 处 理 器 相关 ， 因 而 导致 程序 缺乏 移植 性 。 我 
们 采用 的 蔡 代 策略 是 使 用 一 些 经 典 的 数学 表达 式 来 描述 复杂 的 数学 运算 。 下 面 是 一 个 表 
达 式 的 例子 : 


AxSin(2xPI+ B)/C 


上 式 中 的 4，B，C 代表 数字 ， 而 PI = 3.14159。 


这 看 起 来 不 错 ， 为 什么 不 动手 尝试 一 下 呢 ? 假设 在 某 个 文本 文件 中 有 这 样 一 个 表达 
式 ， 那 么 我 们 可 以 尝试 编写 一 个 汇编 语言 程序 来 读 取 该 文本 文件 ， 并 将 其 中 的 数学 表达 
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如 果 只 需要 计算 一 次 该 表达 式 ， 那 么 可 以 手工 计算 或 借助 计算 器 来 完成 。 如 果 需 要 
对 4、B、C 取 不 同 的 值 多 次 计算 该 表达 式 ， 那 么 你 可 能 要 考虑 使 用 计算 机 来 完成 这 些 计 
算 。 因 此 ， 代 数 表 达 式 不 会 孤立 地 出 现 ， 必 须 考虑 其 前 后 的 语句 ， 这 些 语句 使 表达 式 对 
不 同 的 值 进行 运算 。 


现在 你 所 创建 的 东西 已 经 触及 所 谓 的 高 级 程序 设计 语言 ( high-level programming 
language )。 我 们 一 直 在 介绍 的 汇编 语言 称 做 低级 语言 (low-level programming language )， 
因为 它 与 计算 机 硬件 的 关系 相当 紧密 。 尽 管 除 了 汇编 语言 以 外 的 其 他 程序 设计 语言 都 可 
以 称 为 “高 级 语言 "， 但 它们 之 间 还 是 有 高 低 之 分 的 ， 一 些 语言 通常 被 认为 比 别 的 语言 
高 级 。 如 果 你 是 一 家 公司 的 总 裁 ， 坐 在 计算 机 前 输入 这 些 命 令 (也 可 能 做 得 更 轻松 : 口 
头发 布 这 个 命令 ),“ 计 算出 本 年 度 的 收益 和 损耗 ， 生 成 年 度 报表 ， 最 后 打印 出 2000 份 送 
至 每 个 股东 ”， 你 所 使 用 的 才 真 正 是 一 种 非常 高 级 的 语言 ! 但 在 实际 工作 中 ， 程 序 设 计 语 
言 还 达 不 到 这 种 理想 化 的 水 平 。 


人 类 语言 通常 都 是 经 历 了 干 百 年 复杂 的 互相 影响 、 偶 然 演变 以 及 不 断 吐 故 纳 新 才 形 
成 的 ， 就 算 一 些 人 工 语 言 如 世界 语 ( Esperanto)， 也 处 处 显露 出 与 现实 语言 的 渊源 。 但 高 
级 程序 设计 语言 是 经 过 深思 熟 虑 的 设计 的 ， 更 加 概念 化 的 语言 。 设 计 程 序 设 计 语 言 所 面 
临 的 一 大 挑战 就 是 ， 如 何 让 语言 更 具 吸 引力 。 因 为 语言 定义 了 人 们 向 计算 机 传送 指令 的 
方式 ， 只 有 更 易 用 的 方式 才能 让 人 们 对 语言 产生 兴趣 。 据 1993 年 的 一 项 估算 ， 从 1950 
年 到 1993 年 大 约 有 1000 多 种 高 级 程序 设计 语言 被 发 明 出 来 并 被 应 用 。 


然而 ， 仪 仪 定义 〔 define ) 高 级 语言 ， 包 括 定义 语言 的 语法 ( syntax ) 来 表达 该 语言 
可 以 描述 的 一 切 事物 ， 还 远 远 不 够 ; 我 们 还 需要 为 其 编写 一 个 编译 器 ( compiler )， 编 译 
器 可 以 将 高 级 语言 的 程序 语句 转换 成 机 器 码 指 令 。 同 汇编 器 类 似 ， 编 译 器 也 是 逐 字 逐 名 
地 读 取 源 文件 并 将 其 分 解 成 为 短语 、 符 号 和 数字 的 ， 但 实现 过 程 要 比 汇 编 器 更 加 复杂 。 
从 某 些 方面 来 看 ， 沪 编 右 相对 简单 ， 因 为 汇编 语言 的 语句 和 机 器 码 是 一 一 对 应 的 。 而 一 
般 的 高 级 语言 却 不 具备 这 种 对 应 关系 ， 编 译 器 通常 必须 把 一 条 语句 转换 多 个 机 器 码 指令 。 
编译 器 的 编写 非常 复杂 ， 许 多 书 都 是 用 全 部 的 篇 幅 来 讲解 如 何 设计 和 构造 编译 器 。 


当然 ， 任 何事 物 都 是 具有 两 面 性 的 ， 高 级 语言 也 不 例外 ， 它 有 很 多 优势 但 也 存在 不 
少 缺 陷 。 高 级 语言 最 基本 的 优点 在 于 它 比 汇编 语言 易于 学 习 并 且 更 容易 编写 程序 ， 用 高 
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级 语言 编写 的 程序 通常 更 加 清晰 简明 一 一 与 汇编 语言 不 同 , 高 级 语言 通常 不 依赖 于 特定 的 
处 理 器 ， 因 此 它们 通常 具有 良好 的 可 移植 性 。 因 为 这 种 特点 ， 使 用 高 级 语言 的 程序 员 不 
再 需要 关心 最 终 运行 程序 的 计算 机 的 底层 结构 。 当 然 ， 如 果 要 在 不 同类 型 的 处 理 器 上 运 
行程 序 ， 则 需要 用 处 理 器 对 应 的 编译 器 将 程序 转换 成 对 应 的 机 器 码 。 因 此 ， 最 后 生成 的 
可 执行 文件 仍然 只 适用 于 特定 的 处 理 器 。 


另 一 方面 ， 有 一 种 普遍 现象 : 一 个 优秀 的 汇编 程序 员 所 编写 的 程序 比 编译 器 所 产生 
的 代码 更 加 有 效率 。 也 就 是 说 ， 从 高 级 语言 程序 生成 的 可 执行 程序 比 相同 功能 的 汇编 语 
言 程序 更 大 ， 并 且 运 行 速度 更 慢 (但 从 近年 的 发 展 来 看 ， 这 种 差别 已 变 得 不 再 明显 ， 因 
为 微 处 理 器 变 得 更 加 复杂 ， 而 且 编 译 器 在 优化 代码 方面 也 更 加 成 熟 ) 


此 外 ， 虽 然 高 级 语言 提高 了 处 理 器 的 易 用 性 ， 但 并 没有 让 其 变 得 更 强大 。 微 处 理 器 
的 任何 一 个 功能 都 可 以 通过 汇编 语言 实现 ， 因 此 汇编 语言 可 以 高 度 利用 处 理 器 的 功能 。 
因为 高 级 语言 必须 转化 成 机 器 码 ， 所 以 它 只 会 降低 微 处 理 器 的 能 力 。 事 实 上 ， 如 果 某 种 
高 级 语言 具有 真正 意义 的 可 移植 性 ， 那 么 它 将 木 能 使 用 某 些 处 理 器 的 特有 功能 。 


例如 ， 许 多 微 处 理 器 都 有 移 位 指令 。 如 前 所 述 ， 这 些 指令 能 将 累加 器 中 的 字 节 的 每 
一 位 向 左 或 向 右 移 动 。 但 事实 上 ， 几 乎 没有 哪 一 种 高 级 语言 包含 这 种 操作 。 如 果 在 程序 
中 需要 进行 移 位 操作 ， 则 必须 通过 乘 2 或 除 2 来 模拟 该 过 程 (这 并 不 是 什么 坏事 : 事实 
上 , 许多 现代 编译 器 都 是 利用 处 理 器 的 移 位 指令 来 实现 乘 以 或 除 以 2 的 宅 的 )。 除 此 之 外 ， 
许多 高 级 语言 也 不 包括 按 位 逻辑 运算 。 


在 早期 的 家 用 计算 机 中 ， 大 部 分 应 用 程序 都 是 用 汇编 语言 写 的 ， 而 现在 除了 一 些 特 
殊 的 应 用 场合 之 外 ， 汇 编 语 言 已 经 很 少 使 用 了 。 而 今 处 理 器 引入 了 一 些 新 的 硬件 ， 可 以 
实现 流水 线 技术 一 一 同时 有 若干 个 指令 但 产 次 执行 一 一 这 使 得 汇编 语言 变 得 更 加 复杂 且 
不 易 处 理 。 与 此 同时 ， 编 译 器 却 变 得 更 加 成 熟 ， 越 来 越 多 的 程序 开始 使 用 高 级 语言 来 编 
写 。 现 代 计算 机 大 容量 的 存储 器 也 作为 一 个 重要 的 角色 ， 推 动 了 这 种 趋势 : 程序 员 不 再 
局 限于 编写 运行 在 小 内 存 和 小 磁盘 上 的 程序 。 


早期 的 计算 机 设计 者 都 曾 党 试用 数学 符号 来 描述 问题 ， 但 公认 的 第 一 个 真正 可 以 工 
作 的 编译 器 是 A-0， 它 是 为 UNIVAC 开发 的 编译 器 ， 于 1952 年 由 雷 明 顿 兰 德 公司 
( Remington-Rand ) 的 格 瑞 斯 . 穆 雷 ' 霍 珀 (Grace Murray Hopper，1906-1992 ) 开发 完成 。 
霍 珀 博士 的 早期 计算 机 研究 工作 始 于 1944 年 ， 那 时 好 效力 于 霍华德 艾 肯 (Howard 
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加 


Aiken )， 主 要 研究 Mark I 。 在 她 八 十 多 岁 的 时 候 ， 仍然 孜孜 不 倦 地 在 计算 机 界 工 作 ， 当 
时 她 在 DEC (Digital Equipment Corporation ) 公司 从 事 公关 事务 。 


FORTRAN 语言 是 目前 仍 在 使 用 的 最 古老 的 高 级 语言 ( 虽然 这 些 年 来 人 们 对 其 进行 了 

大 量 修改 )。 你 可 能 注意 到 了 ， 很 多 计算 机 语言 都 是 以 大 写字 母 命名 的 ， 这 是 因为 它们 的 
和 名字 大 都 是 由 几 个 单词 的 首 字 母 组 成 。FORTRAN 这 个 名 字 来 源 于 FORmula 的 前 三 个 字 
母 和 TRANSslation 的 前 四 个 字母 的 组 合 ， 它 由 IBM 在 20 世纪 50 年 代 中 期 开发 ， 主 要 应 
用 于 704 系列 计算 机 。 自 其 发 布 的 几 十 年 来 , FORTRAN 一 直 被 认为 是 科学 和 工程 应 用 程 
序 开发 的 首选 语言 。 它 广泛 地 支持 浮 点 运算 ， 甚 至 支持 非常 复杂 的 数 的 运算 ( 即 我 们 上 
章 讲 到 的 由 实数 和 虚数 构成 的 复数 )。 


任何 一 种 计算 机 程序 设计 语言 都 有 其 支持 者 和 批评 者 ， 而 且 人 们 通常 只 对 自己 喜欢 
的 语言 有 热情 。 本 书 尽量 以 一 种 客观 的 态度 来 讨论 某 种 语言 ， 这 里 选取 了 一 种 语言 作为 
原型 ， 通 过 它 来 解释 那些 几乎 已 经 销声匿迹 的 程序 设计 概念 。 我 们 的 选择 是 ALGOL ( 即 
ALGOrithmic 的 缩写 ， 有 趣 的 是 ，ALGOL 也 是 仙女 座 第 二 亮 的 恒星 的 名 字 )。 ALGOL 作 
为 过 去 40 年 中 许多 曾经 流行 一 时 的 通用 高 级 语言 的 直接 鼻祖 ， 也 非常 适合 用 来 研究 高 级 
程序 设计 语言 的 本 质 ， 该 语言 可 看 做 是 一 粒 种 子 ， 它 的 成 长 最 终 形成 了 高 级 语言 这 棵 大 
树 。 直 到 今天 ， 人 们 仍然 在 使 用 “类 ALGOL” 程 序 设计 语言 的 概念 。 


ALGOL 语言 的 原版 由 某国 际 委 员 会 在 1957 至 1958 年 间 设 计 , 它 被 称 做 ALGOL 58。 
两 年 后 , 也 就 是 在 1960 年 , ALGOL 58 的 改进 版 ALGOL 60 面世 , 其 最 终 版 本 是 ALGOL 
68。 本 章 所 采用 的 版 本 在 Revised Report on the 4lgorithmic Language ALGOL 60 说 明文 档 
中 有 具体 描述 ， 该 文档 于 1962 年 完成 并 在 1963 年 首次 发 行 。 


让 我 们 开始 写 第 一 个 ALGOL 程序 。 假 设 我 们 使 用 的 操作 系统 平台 是 CP/M 或 
MS-DOS， 并 旦 安装 了 一 个 名 为 ALGOL.COM 的 编译 器 。 该 程序 是 一 个 文本 文件 ， 命 名 
为 FIRST.ALG。 注 意 ， 文 件 类 型 名 是 ALG。 


ALGOL 程序 以 begin 开始 ， 以 end 作为 结尾 ， 程 序 的 主要 内 容 被 包括 在 这 两 个 语句 
之 间 。 下 面 的 程序 用 来 显示 一 行文 本 : 


begin 
print ('This is my fist ALGOL program!'); 


ende 
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通过 在 命令 行 运行 ALGOL 编译 器 对 FIRST.ALG 文件 进行 编译 ， 其 格式 如 下 : 


ALGOL FIRST.ALG 


ALGOL 编译 器 对 这 条 命令 很 可 能 做 出 这 种 响应 ， 在 显示 设备 上 给 出 以 下 提示 信 ， 


证 


Line 3: Unrecognized keyword '‘'ende'. 


ALGOL 编译 器 对 拼写 的 检查 非常 严格 , 它 在 这 一 点 上 比 传统 的 语文 教师 更 其 。 因 为 
输入 程序 时 ， 误 把 “end” 拼 写 做 “ende”， 所 以 编译 器 通过 提示 信息 告诉 我 们 程序 中 有 语 
法 错误 (syntax error )。 当 编译 器 检查 到 “ende” 时 ， 它 期 待 能 遇 到 一 个 可 识别 的 关键 字 
( keyword )， 但 由 于 上 述 错误 ， 编 译 不 能 通过 。 


将 程序 中 的 错误 改正 之 后 ， 可 以 再 次 执行 编译 命令 。 由 于 系统 平台 和 编译 器 版 本 的 
不 同 ， 有 时 编译 器 会 直接 生成 一 个 可 执行 文件 ( CP/M 平台 下 此 文件 名 为 FIRSTCOM， 
MS-DOS 平台 下 名 为 FIRSTEXE ); 有 时 还 需要 再 执行 一 个 步骤 才 可 以 完成 。 不 论 是 哪 种 
情况 ， 最 后 你 都 可 以 在 命令 行 执行 FIRST 程序: 


FIRST 


FIRST 程序 会 对 此 响应 ， 并 显示 以 下 内 容 : 


This is my fist ALGOL program! 


注意 ， 这 里 还 有 一 个 拼写 错误 : first 被 误 做 fist! 编译 器 没有 检查 出 这 个 错误 ， 因 此 
它 被 称 为 运行 时 错误 (run-time error ) 一 一 程序 被 执行 时 才 出 现 的 错误 。 


很 明显 ,我 们 的 第 一 个 ALGOL 程序 中 ，print 语句 的 功能 是 把 一 些 信息 显示 到 屏幕 
上 ,在 本 程序 中 是 显示 一 行文 本 ( 从 功能 的 角度 来 看 ， 该 程序 与 本 章 开始 所 给 出 的 汇编 
程序 是 等 价 的 )。ALGOL 语言 的 正式 规范 中 并 不 包括 print 语句 ， 但 我 们 假设 所 使 用 的 特 
定 ALGOL 编译 器 包括 这 个 便利 的 工具 ， 它 有 时 候 也 被 称 做 内 部 函数 (built-in fonction )。 
除了 begin 和 end 之 外 的 大 部 分 ALGOL 语句 都 要 以 分 号 结尾 。 你 可 能 注意 到 了 print 语句 
使 用 了 向 右 缩 进 的 格式 ， 这 并 不 是 必要 的 ， 其 作用 只 是 为 了 让 程序 的 结构 更 加 清晰 。 


假设 现在 要 编写 一 个 用 于 两 个 数 相 乘 的 程序 。 每 一 种 程序 设计 语言 都 包括 变量 


( variable ) 的 概念 。 程 序 中 的 变量 可 以 是 一 个 字母 、 一 个 短 的 字母 序列 ， 也 可 以 是 一 个 单 
词 ， 由 程序 员 自己 决定 。 变 量 名 实际 上 对 应 内 存 的 一 个 存储 单元 ， 但 在 程序 中 是 通过 名 
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字 来 访问 该 存储 单元 的 ， 而 不 是 直接 使 用 存储 单元 的 地 址 值 。 下 面 的 程序 定义 了 三 个 变 
量 , 分别 命名 为 a,，b，, c: 


begin 

real ar b, c; 

a = 59535437 

b := 289.771; 

C := a x b; 

print ('The product of', a, ' and ', b, ' is ', c); 
end 


real 语句 称 为 声明 (declaration ) 语句 ， 用 来 指明 程序 中 要 定义 的 变量 。 在 该 程序 中 ， 
变量 a,，b,c 被 定义 为 实数 〈real ) 类 型 或 浮 点 数 类 型 (同时 ，ALGOL 语言 也 支持 使 用 
integer 关键 字 来 定义 整数 型 变量 )。 程 序 设 计 语 言 中 的 变量 名 通常 以 字母 开头 ， 变 量 名 也 
可 以 包括 数字 ， 但 前 提 是 第 一 个 字符 必须 是 字母 。 变 量 名 不 能 含有 空格 ， 也 不 能 包含 除 
字母 和 数字 以 外 的 其 他 大 部 分 字符 。 通 常 编 译 器 会 规定 变量 名 的 最 大 长 度 ， 本 章 用 到 的 
变量 一 律 以 单个 字母 命名 。 


假如 我 们 使 用 的 特定 ALGOL 编译 器 支持 EEE 浮 点 数 标 准 ， 则 本 程序 中 所 定义 的 三 
个 变量 每 一 个 需要 4 个 字 节 的 存储 空间 ( 采用 单 精度 格式 ) 或 8 个 字 节 的 存储 空间 ( 采 
用 双 精 度 格式 )。 


声明 语句 之 后 的 三 个 语句 是 赋值 (assignment ) 语句 。 在 ALGOL 语言 中 ， 赋 值 语 名 
很 容易 被 识别 ， 因 为 它 的 格式 很 固定 ， 总 是 在 冒号 后 面 跟着 一 个 等 号 (在 大 多 数 计算 机 
语言 中 ， 赋 值 语 句 通常 只 包括 等 号 )。 赋 值 语句 的 冒号 左边 是 一 个 变量 ， 而 等 号 右边 是 
个 表达 式 ， 表 达 式 的 计算 结果 将 被 赋值 给 左边 的 变量 。 前 两 条 赋值 语 名 指明， 变量 a, 4 
将 分 别 被 赋予 一 个 特定 的 值 ; 第 三 条 赋值 语句 指明 ， 将 a 和 2 的 乘积 赋值 给 变量 c。 


时 至 今日 ， 我 们 所 熟悉 的 乘法 符号 “x” 已 经 不 允许 出 现在 程序 设计 语言 中 了 ， 因 为 
它 没有 被 包括 在 ASCI 和 EBDCIC 字符 集中 。 大 多 数 程序 设计 语言 使 用 星 号 (* ) 来 替代 
它 作 为 程序 中 的 姜 号 标记 。 尽 管 ALGOL 使 用 了 普遍 使 用 的 斜 杜 (/) 作为 除法 标记 ,但 
在 该 语言 仍然 可 以 使 用 除法 标记 (+)， 该 标记 用 于 整数 除法 ， 用 来 指明 被 除数 与 除数 的 
倍数 关系 。ALGOL 还 使 用 了 另 一 个 非 ASCII 字符 “人 f” ， 该 箭头 符号 用 来 做 乘 方 运算 。 


最 后 的 print 语句 用 来 显示 所 有 变量 的 值 。 它 包含 文本 和 变量 ， 并 以 和 逗号 分 隔 。print 
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一 个 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语 


语句 的 主要 工作 并 不 是 用 来 显示 ASCII 码 值 的 ， 但 本 程序 中 却 做 了 更 多 的 工作 : 将 浮 点 
数 也 转换 成 了 ASCI 码 并 显示 : 


The product of 535.43 and 289.771 is 155152.08653 


接着 会 执行 end 语句， 程序 终止 并 将 控制 权 交 还 给 操作 系统 。 


[ 果 要 将 另外 两 个 数 相 乘 ， 则 需要 做 以 下 工作 : 修改 程序 ， 改 变 变量 的 值 ， 重 新 编 
译 并 重新 运行 程序 ， 这 将 是 一 件 非常 烦 琐 的 工作 。 为 了 避免 这 些 重复 工作 ， 我 们 可 以 借 
助 于 另 一 个 内 部 函数 read。 修 改 后 的 程序 如 下 : 


+ 


begin 

real a, b, c; 

print ('Enter 七 he first number; ')}; 

read (a); 

print ('Enter the second number: ');，; 

read (Db); 

C :=a x b; 

print ('The Prodquct of ', a, ' anG ', b, ' is ', c); 
end 


read 语句 的 功能 是 读 取 从 键盘 键入 的 ASCII 码 值 ， 并 将 其 转换 成 浮 点 数 。 

循环 (loop ) 是 高 级 语言 的 重要 组 成 部 分 。 循 环 使 得 程序 可 以 对 同一 个 变量 的 不 同 取 
值 反 复 执行 相同 的 操作 。 假 设 我 们 要 写 一 段 程序 用 来 计算 3，5，7，9 各 自 的 平方 ， 可 以 
这 样 编写 程序 : 


begin 


real a, b; 


for a := 3, 5, 7, 9 do 
begin 
b :=axa x a; 
print ('The cube of ', a, " is ', b); 
end 
end 


for 语句 将 变量 a 的 值 第 一 次 设 为 3， 然 后 执行 do 关键 字 后 面 的 语句 。 如 果 do 后 面 
要 执行 的 语句 不 止 一 条 (如 本 例 )， 则 必须 将 它们 置 于 begin 和 end 之 间 ， 这 两 个 关键 字 
定义 了 一 个 语句 块 (block )。 第 一 次 循环 之 后 ，for 语句 会 一 次 为 a 赋值 S，7，9 并 执行 
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相同 的 语句 块 。 


下 面 的 程序 中 采用 了 for 语句 的 另 一 种 使 用 方式 , 这 段 程 序 用 来 计算 3~99 之 间 所 有 
奇数 的 立方 。 


begin 
real a, b; 
for a := 3 step 2 until 99 do 
begin 
b := a x*xax ar 
print ('The cube of ', a, ' is ', b); 
end 
end 


for 语句 将 变量 a 初始 化 为 3， 并 执行 for 后 面 的 语句 块 。 第 一 次 循环 结束 后 ， 变 量 a 
与 step 关键 字 后 面 的 增 量 相 加 ， 这 里 是 2。 新 得 到 的 a 的 值 是 5， 它 将 用 于 第 二 次 执行 语 
句 块 。 变 量 a 继续 增加 2 并 用 于 下 一 次 循环 ， 直 到 a 的 值 超过 99， 这 时 for 循环 结束 。 


一 般 而 言 ， 程 序 设计 语言 对 语法 都 有 着 非常 严格 的 要 求 。 在 ALGOL 60 中 ， 就 关键 
字 for 而 言 ， 其 语法 格式 是 : for 的 后 面 只 能 跟 一 个 变量 名 。 而 英语 中 的 这 种 限制 宽松 的 
多 ,单词 for 的 后 面 可 以 跟 所 有 类 型 的 单词 ， 例 如 “for example”,“for can” 等 。 尽 管 编 
译 器 是 非常 复杂 的 程序 ， 但 其 所 能 解释 的 语言 显然 要 比 人 类 的 语言 简单 得 多 。 


大 部 分 程序 设计 语言 的 男 一 个 重要 特征 体现 在 条 件 ( conditional ) 语句 的 使 用 。 条 件 
语句 的 特点 是 ， 只 有 当 菜 个 条 件 成 立时 才 会 执行 男 一 条 对 应 的 语句 。 在 下 面 的 例子 中 ， 
我 们 使 用 ALGOL 的 内 部 函数 sqrt 来 计算 一 些 数 的 平方 根 。sqrt 函数 的 参数 不 能 是 负数 ， 
因此 要 在 程序 中 通过 条 件 测 试 避免 这 种 情况 。 


begin 
real a, b; 


print ('Enter a number: '); 
read (a); 
if a < 0 then 
print ('Sorry, the number was negative.'); 
else 
begin 
b= sgqrt(a); 
print ('The square root of ', a, ' is ', b); 
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一 下 编码 一 -隐匿 在 计算 机 软 硬 件 背 后 的 语言 
过 CA > 


end 
end 


左 尖 括号 (<) 是 小 于 号 。 如 果 程 序 的 使 用 者 输入 的 是 一 个 小 于 0 的 数 ,让 语 名 中 的 . 
判断 语句 为 真 ， 因 此 第 一 个 print 语句 将 会 被 执行 。 反之 ,如果 该 数 大 于 或 等 于 0, 则 else 
关键 字 后 面 的 语句 块 则 会 被 执行 。 

本 章 目前 所 用 到 的 变量 都 是 一 个 变量 对 应 一 个 值 ， 我 们 也 可 以 用 一 个 变量 对 应 多 个 
值 ， 数 组 (array ) 就 是 一 个 很 好 的 选择 。 在 ALGOL 程序 中 可 以 这 样 声明 一 个 数组 : 


real array a[lli:100]; 


该 语 名 定义 一 个 数组 变量 a, 它 可 以 用 来 存放 100 个 不 同 的 浮 点 数 ， 这些 数 被 称 做 数 
组 元 素 。 可 以 使 用 数组 名 加 标号 的 方式 来 引用 数组 元 素 ， 例如， 第 一 个 数组 元 素 是 a[1]， 
第 二 个 是 a[2]， 最 后 一 个 是 a[100]。 方 括号 中 的 数字 称 做 数组 下 标 (index )。 


下 面 的 程序 用 来 计算 1 ~ 100 所 有 数 的 平方 根 ， 将 结果 保存 在 一 个 数组 中 ， 然 后 再 通 
过 循环 将 这 些 结果 显示 出 来 。 代 码 如 下 : 


begin 


real array al[ll:100]; 

integer i; 

for i := 1 step 1 until 100 do 
a[li] := sqgqrt (i); 


for i := 1 step 1 until 100 do 
print ('The square root of ', i, ' is ', a[lil]); 
end 
程序 中 还 定义 了 一 个 整 型 变量 i( 由 于 它 是 integer 的 首 字母 , 经 常 被 程序 员 用 做 整 型 
变量 名 )。 第 一 个 for 循环 的 执行 过 程 中 ， 每 个 数组 元 素 被 赋值 为 其 下 标的 平方 根 ; 第 二 
个 for 循环 执行 过 程 中 ， 数 组 中 的 每 一 个 元 素 被 显示 出 来 。 


变量 的 类 型 有 很 多 ， 除 了 我 们 已 经 介绍 过 的 实 型 和 整 型 之 外 ， 变 量 还 可 以 被 声明 为 
布尔 型 ( Boolean， 该 名 称 是 为 了 纪念 第 10 章 提 到 的 乔治 : 布尔 )。 布 尔 变量 的 取 值 只 可 
能 有 两 种 ， 即 true 和 false。 在 本 章 的 最 后 将 介绍 一 个 用 到 布尔 数组 的 例子 ( 这 个 例子 也 
将 用 到 目前 所 介绍 的 大 部 分 内 容 )， 来 实现 一 个 寻找 素数 的 著名 算法 一 一 爱 拉 托 还 斯 第 法 
( Sieve of Eratosthenes )。 爱 拉 托 还 斯 ( 约 公元 前 276-196 年 ) 传说 是 亚历山大 图 书馆 的 管 
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理 员 ， 他 因 准 确 计 算出 地 球 的 周 长 而 永 载 史册 。 


素数 是 只 能 被 1 及 其 本 身 整 除 的 一 类 整数 。 第 一 个 素数 是 2 ( 也 是 唯一 的 偶数 素数 )， 
其 他 的 素数 还 包括 3，5，7，11，13，17， 等 等 。 


爱 拉 托 逊 斯 方法 以 2 开始 的 整数 表 开始 ， 因 为 2 是 素数 ， 因 此 所 有 可 以 被 2 整除 的 
数 都 被 排除 掉 ( 即 除 了 2 之 外 的 全 部 偶数 )。 接 下 来 是 3， 因 为 3 是 素数 ， 因 此 所 有 能 被 
3 整除 的 数 也 被 排除 掉 。 因 为 4 在 第 一 个 步骤 中 已 经 被 排除 掉 ， 所 以 下 一 个 要 考虑 的 数 是 
5， 即 排除 所 有 5 的 倍数 。 按 这 种 方式 不 断 循 环 ， 最 后 剩 下 的 都 是 素数 。 


下 面 的 ALGOL 程序 用 来 筛选 2 ~ 10,000 之 间 的 所 有 素数 , 程序 中 定义 了 一 个 布尔 数 
组 ， 用 来 对 所 有 的 数 进行 标识 。 该 程序 如 下 : 
begin 


Boolean array a[2:100001]:， 
integer i, j; 


for i := 2 step 1 until 10000 do 
a[lil] := true; 
for i := 2 step 1 until 100 do 
if afi] then 
for ] := 2 step 1 until 10000 = i do 
ali x 3j] := false; 
for i := 2 step 1 until 10000 do 


if al[lil] then 
Print (i); 
end 


第 一 个 far 循环 将 数组 a 的 每 一 个 元 素 的 初始 值 设置 为 布尔 值 tue。 这 里 的 true 表示 
该 位 置 的 数 是 素数 ， 因 此 现在 程序 默认 所 有 的 数 都 是 素数 。 第 二 个 for 循环 的 范围 是 1 ~ 
100 ( 100 刚好 是 10000 的 平方 根 )。 在 第 二 个 for 循环 中 ， 如 果 判 断 条 件 成 立 ， 该 数 为 素 
数 ， 即 ea 四 为 tue， 则 第 三 个 for 循环 则 会 把 该 数 的 所 有 小 于 或 等 于 10000 的 倍数 (除了 
其 本 身 ) 设置 为 false， 因 为 这 些 数 都 不 是 素数 。 最 后 的 for 循环 用 来 输出 所 有 的 素数 ,这 
里 的 判断 条 件 是 : 若 ali] 为 tue， 则 ;为 素数 。 | 


， 程 序 设计 到 底 是 一 门 科学 还 是 一 门 艺术 昵 ? 这 的 确 是 一 个 有 趣 的 问题 ， 一 些 人 甚至 
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还 为 此 争论 不 体 : 一 方面 ,你 或 许 在 大 学 里 系统 地 学 习 了 计算 机 科学 ( Computer Science ) 
课程 ， 男 一 方面 ， 你 又 读 过 如 唐纳德 . 克 努 斯 ( Donald Knuth ) 的 名 著 《 计 算 机 编程 艺术 
系列 》( The 4rt of Computer Programming series ) 等 著作 。 然 而 物理 学 家 理 查 德 * 费 叶 曼 
( Richard Feynman ) 曾 这 样 写 道 :“ 从 某 种 程度 上 看 计算 机 科学 像 是 一 种 工程 ， 它 的 工作 
范畴 是 利用 一 些 事物 去 实现 其 他 事物 。 


在 程序 设计 中 有 一 种 现象 : 如 果 让 100 个 人 来 编写 输出 素数 的 程序 ， 你 可 能 会 得 到 
100 个 不 同 的 解决 方法 。 厌 算 所 有 的 程序 员 都 使 用 “ 爱 拉 托 逊 斯 得 法 ”来 解决 这 个 问题 ， 
其 最 后 所 写 的 程序 也 不 一 定 与 本 文 所 写 程 序 完全 相同 。 如 果 说 程序 设计 是 一 门 科 学 ， 那 
么 就 不 应 该 出 现 如 此 多 的 解法 ， 而 不 正确 的 方法 将 会 非常 明显 。 偶 尔 ， 一 个 程序 设计 问 
题 会 诱发 出 极 富 创造 性 的 火花 或 洞 若 观 火 般 的 觉察 力 , 这 就 是 所 谓 的 程序 设计 的 “艺术 ”。 
但 是 ， 程 序 设计 的 更 多 的 时 候 是 设计 和 建造 ， 就 像 修建 一 座 大 桥 的 过 程 。 


早期 的 程序 设计 对 编程 人 员 的 要 求 很 高 ， 所 以 很 多 早期 的 程序 员 都 是 科学 家 或 工程 
师 ， 他 们 通常 利用 FORTRAN 或 ALGOL 中 的 数学 算法 来 描述 并 解决 各 自 领域 的 问题 。 

回顾 程序 设计 语言 发 展 的 整个 历程 时 ， 我 们 会 发 现 ， 人 们 一 直 在 努力 开发 一 种 能 为 更 大 
范围 的 人 群 所 使 用 的 语言 。 


”第 一 个 成 功 地 为 商务 系统 所 使 用 的 程序 设计 语言 是 COBOL ( COmmon Business 
Oriented Language )， 今 天 它 仍 然 被 广泛 使 用 。COBOL 于 1959 年 开始 开发 ， 由 美国 工业 
界 和 国防 部 组 成 的 委员 会 发 起 并 实施 ， 它 的 设计 思路 受到 格 瑞 斯 ， 霍 珀 早期 编译 器 的 影 
响 。 从 菜 些 方面 来 看 ，COBOL 的 设计 中 渗透 了 这 种 思想 : 使 管理 人 员 一 可 能 并 不 进行 
实际 的 编码 工作 一 一 但 他 们 至 少 可 以 看 懂 程 序 代码 , 而 且 能 够 检测 程序 能 否 完成 预定 工作 
( 实际 上 这 种 情况 非常 少见 )。 


COBOL 语言 广泛 支持 读 取 记录 (record ) 和 生成 报表 (report )。 记 录 是 按照 统一 方 
式 归 类 整理 的 信息 的 集合 。 例 如 ， 保 险 公司 一 般 会 维护 一 个 包括 其 所 售 的 所 有 保险 信息 
的 大 型 文件 ， 每 一 项 保险 业务 称 为 一 条 单独 的 记录 。 每 一 条 记录 包括 客户 的 姓名 、 出 生 
日 期 等 信息 。 早 期 编写 的 COBOL 程序 , 大 都 是 为 了 处 理 存 储 在 IBM 打 和 孔 卡 片上 的 80 列 
记录 而 编写 的 。 为 了 尽量 减少 孔洞 所 占用 的 卡片 空间 ， 年 份 通常 设计 成 2 位 而 不 是 4 位 ， 
随 着 时 间 的 推移 ， 这 个 设计 的 缺陷 逐渐 显露 出 来 ,最终 导致 在 2000 年 出 现 了 著名 的 “ 干 
年 虫 问题 ”( millennium bug )。 
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在 20 世纪 60 年 代 中 期 ， 为 了 配合 System/360 项 目的 开发 ，IBM 同时 开发 了 程序 设 
计 语 言 PL/1( I 是 罗马 数字 中 的 1, 因此 PL/ 了 的 含义 是 : Programming Language Number 
One )。PL/ I 的 设计 者 们 想 要 使 其 融合 ALGOL 的 块 结构 ，FORTRAN 语言 的 数学 函数 功 
能 以 及 COBOL 处 理 记 录 和 和 报表 的 能 力 ,但 该 语言 却 远 没有 达到 FORTRAN 和 COBOL 那 
样 广泛 的 使 用 程度 。 


虽然 FORTRAN，ALGOL，COBOL 以 及 PL/1I 都 可 以 应 用 于 家 用 计算 机 ， 但 它们 对 
于 小 型 计算 机 的 影响 远 没有 BASIC 语言 那么 深远 。 


BASIC ( Beginner’s All-purpose Symbolic Instruction Code ) 由 达 特 茅 斯 (Dartmouth ) 
. 大 学 数学 系 的 约翰 克 莫 尼 (John Kemeny ) 和 托马斯 ， 克 鲁 兹 (Thomas Kurtz ) 在 1964 
年 开发 ， 该 语言 最 初 是 为 达 特 茅 斯 分 时 系统 和 而 设计 的 。 达 特 茅 斯 大 学 的 学 生 并 非 数学 或 
工程 专业 ， 因 此 他 们 不 应 该 为 打 孔 卡片 和 复杂 的 程序 语法 花费 太 多 精力 ， 他 们 要 做 的 只 
是 端 坐 于 计算 机 终端 前 , 在 数字 后 面 输 入 一 些 BASIC 语句 来 完成 编程 。 BASIC 语句 前 的 
数字 用 来 指明 该 语句 在 程序 中 的 次 序 。 前 面 没有 数字 的 语句 是 系统 命令 , 如 SAVE (将 
BASIC 程序 保存 至 磁盘 )，LIST【( 按 顺 序 显示 行 ) 以 及 RUN (编译 并 运行 程序 )。BASIC 
手册 的 第 一 版 中 的 第 一 个 程序 是 这 样 的 : 


10 LET X= (7+8) /3 
20 PRINT X 
30 END 


与 ALGOL 语言 不 同 ，BASIC 不 要 求 程序 员 指定 变量 的 存储 类 型 ， 究 竟 一 个 变量 是 
保存 为 整 型 还 是 浮 点 型 并 不 需要 程序 员 担 心 ， 大 部 分 数 默认 都 是 以 浮 点 数 格 式 存储 的 。 


民 多 BASIC 的 后 续 版 本 都 是 解释 型 〈interpreter ) 而 不 是 编译 型 《compiler )。 如 前 所 
述 ， 编 译 器 读 取 源 文件 并 生成 一 个 可 执行 文件 ; 而 解释 器 却 采 取 边 读 边 执行 的 方式 ， 不 
会 产生 新 的 文件 。 解 释 器 比 编译 器 的 原理 简单 一 些 ， 因 此 更 容易 编写 ， 但 其 运行 程序 的 
速度 要 比 后 者 要 慢 。 BASIC 语言 应 用 于 家 用 计算 机 的 时 间 较 晚 , 1975 年 , 比尔 ` 盖 茨 (Bi 记 
Gates， 生 于 1955 年 ) 和 其 好 友 保 罗 . 艾 伦 (Paul Allen， 生 于 1953 年 ) 为 Altair 8800 编 
写 了 BASIC 解释 器 , 这 一 事件 可 以 视 为 BASIC 在 此 领域 的 开端 , 同一 年 他 们 创建 了 微软 


公司 (Microsoft Corporation )。 


Pascal 程序 设计 语言 继承 了 ALGOL 的 大 部 分 结构 ， 同 时 还 继承 了 COBOL 的 记录 处 
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理 功 能 ， 它 由 瑞士 计算 机 科学 教授 尼 尔 莱 斯 . 沃 思 (Niklaus Wirth， 生 于 1934 年 ) 在 20 
世纪 60 年 代 末 开 发 完成 。IBM PC 的 程序 员 对 Pascal 非常 青睐 ， 而 备 受 欢迎 Pascal 版 本 
却 是 大 名 网 易 的 Tarbo Pascal。1983 年 ， 宝 兰 公司 ( Borland International ) 发 布 了 Turbo 
Pascal， 当 时 的 售 价 是 49.95 美元 。Turbo Pascal 由 一 名 叫 安 德 斯 ' 海尔 斯 伯 格 (Anders 
Hejlsberg, 生 于 1960 年 ) 的 丹麦 大 学 生 开发 , 它 提供 了 完整 的 集成 化 开发 环境 ( integrated 
development environment )。 程序 的 文本 编辑 器 和 编译 器 集成 在 一 起 , 这 样 就 方便 了 程序 的 
调试 和 运行 , 大 大 加 快 了 程序 开发 速度 。 集成 化 开发 环境 以 前 主要 用 于 大 型 计算 机 , Turbo 
Pascal 实现 了 在 小 型 计算 机 上 的 突破 。 


Pascal 对 Ada 的 影响 也 非常 大 。Ada 是 为 美国 国防 部 开发 应 用 的 一 种 语言 , 它 以 奥 古 
斯 塔 . 艾 达 : 拜 伦 (AugustaAda Byron ) 命名 。 在 第 18 章 曾 提 到 过 , 奥 古 斯 塔 - 艾 达 ' 拜 
伦 是 查尔斯 ， 巴 贝 世 的 解析 机 发 展 历程 的 记录 者 。 


接 下 来 就 是 C, 一 种 深 受 喜爱 的 程序 设计 语言 。C 语言 主要 是 由 贝尔 电话 实验 室 的 丹 
尼斯 M ' 里 奇 (Dennis M.Ritchie ) 开发 的 ， 从 1969 年 开始 设计 并 于 1973 年 开发 完成 。 
人 们 常常 对 为 什么 以 C 来 命名 该 语言 感 兴趣 ， 答 案 其 实 很 简单 ， 它 是 一 种 早期 的 程序 设 
计 语 言 B 的 后 继 者 。B 是 BCPL ( Basic CPL ) 语言 的 一 种 精简 版 本 , 而 BCPL 来 源 于 CPL 
( Combined Programming Language )。 


如 第 22 章 所 述 ，UNIX 操作 系统 在 设计 的 过 程 中 充分 考虑 到 了 可 移植 性 。 当 时 的 许 
多 操作 系统 都 是 基于 某 种 处 理 器 的 ， 并 且 使 用 汇编 语言 编写 ， 基 本 上 没有 可 移植 性 可 言 。 
1973 年 ，UNIX 采用 C 语言 编写 ( 更 准确 地 说 ， 应 该 是 重 写 ) 成 功 ， 从 此 以 后 UNIX 操 
作 系 统 和 C 语言 就 变 得 密 不 可 分 了。 


C 是 一 种 风格 非常 简洁 的 语言 。 例 如 ，ALGOL 和 Pascal 使 用 关键 字 begin 和 end 来 
界定 程序 块 ， 而 在 C 中 这 两 个 单词 被 一 对 大 括号 “{}” 取 代 。 下 面 给 出 一 个 例子 ,程序 
员 常 常会 把 一 个 常量 和 一 个 变量 相 加 ， 比 如 : 


在 C 程序 中 ,你 可 以 将 上 面 的 语句 简写 为 : 


全 和 车 3 


如 果 只 需要 把 变量 加 1 ( 即 增 量 )， 则 该 语句 还 可 以 精简 成 下 面 这 样 : 
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mt A 


1 


在 16 位 或 32 位 微 处 理 器 中 ，i++ 这 种 语句 仪 需要 一 条 机 器 码 指 令 就 可 以 执行 。 


在 本 章 的 前 面 曾 讲 过 ， 很 多 高 级 语言 都 不 支持 移 位 操作 和 按 位 布尔 运算 操作 ， 而 许 


多 处 理 器 其 实 支持 这 类 操作 , C 语言 打破 了 这 种 局 限 , 它 广 泛 地 支持 这 类 运算 。 除 此 之 外 ， 
C 语言 的 另 一 重要 特征 是 对 于 指针 (pointer ) 的 支持 , 指针 本 质 是 数字 化 描述 的 内 存 地 址 。 


C 语言 中 的 很 多 操作 与 通用 处 理 器 的 指令 非常 相似 ， 因 此 C 也 被 称 为 高 级 汇编 语言 


(high-level assembly language )。 与 类 ALGOL 语言 相 比 ，C 的 操作 集 与 通用 处 理 器 的 指令 


集 接 近 程 度 更 高 ， 或 者 说 远 胜 过 它们 。 


但 是 , 所 有 的 类 ALGOL 语言 一 一 即 大 多 数 常 


程序 设计 语言 一 一 其 设计 模式 都 是 基 


于 冯 : 诺 依 曼 计算 机 体系 的 。 设 计 一 种 非 汉 ' 诺 依 曼 体系 的 程序 设计 语言 并 非 易 事 ， 而 
让 人 们 接受 并 使 用 这 种 语言 则 更 加 困难 。LISP ( List Processing ) 是 一 种 非 汉 : 诺 依 曼 体 


系 程序 设计 语言 ， 它 主要 应 用 于 人 工 智能 领域 ， 


约翰 麦卡锡 ( John McCarthy ) 在 20 


世纪 50 年 代 未 期 开发 完成 。APL (A Programming Language ) 是 另 一 种 全 新 的 语言 ， 与 


LISP 完全 不 同 , 它 同样 完成 于 20 世纪 50 年 代 末 期 , 由 肯 尼 斯 - 艾 佛 森 (Kenneth Iverson ) 
开发 。APL 的 特殊 之 处 在 于 ， 它 使 用 一 个 特殊 的 符号 集 ， 利 用 其 中 的 符号 可 以 一 次 性 对 


整个 数组 里 的 数字 完成 操作 。 


类 ALGOL 语言 一 直 在 程序 语言 领域 占据 着 重要 地 位 , 而 且 近 年 来 , 此 类 语言 在 一 些 
方面 进行 了 改进 ， 导 致 面向 对 象 程序 设计 语言 (object-oriented language ) 的 产生 。 面 向 对 
象 语 言 主要 应 用 在 图 形 化 操作 系统 中 ， 我 们 将 会 在 下 一 章 〈 也 是 最 后 一 章 ) 介绍 这 种 操 


作 系 统 。 
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对 于 《生活 》( life ) 杂志 的 读者 而 言 ，1945 年 9 月 10 日 这 一 天 的 杂志 像 以 往 一 样 ， 


到 形 化 革命 


有 很 多 习以为常 的 文章 和 照片: 第 二 次 世界 大 战 结束 的 相关 新 闻 ; 讲述 舞蹈 家 瓦斯 拉 
夫 ' 尼 金 斯 基 ( Vaslav Nijinsky ) 在 维也纳 生活 的 点 点 滴 滴 ; 主题 为 美国 汽车 工人 的 图 片 
新 闻 。 但 同时 , 在 这 一 期 的 杂志 中 还 有 些 不 寻常 的 内 容 : 万 尼 瓦 尔 :布什 (Vannevar Bush 
1890-1974 ) 发 表 了 一 篇 关于 未 来 科学 大 胆 猜 想 的 文章 。 万 : 布什 (人 们 常 这 样 称呼 他 ) 
的 发 明 与 贡献 对 计算 机 历史 产生 了 深远 的 影响 一 一 其 中 最 著名 的 就 是 他 设计 开发 具有 划 
时 代 意 义 的 模拟 计算 机 一 一 微分 分 析 器 (The Differential Analyzer ) 一 一 1927 ~ 1931 年 ， 
当时 万 布什 在 担任 麻 省 理工 学 院 (以 下 简称 为 MIT ) 工程 学 教授 期 间 发 明了 这 个 机 器 。 
这 篇 文章 在 杂志 上 发 表 的 时 候 ， 也 就 是 1945 年 ， 布 什 所 担任 的 职位 是 科学 研究 及 开发 办 
公 室 (Office of Scientific Research and Development，OSRD ) 的 主任 ， 负 责 美国 战 时 科研 
活动 的 协调 工作 ， 其 中 就 包括 了 曼哈顿 计划 (Manhattan Project)。 


万 :布什 将 自己 两 个 月 前 在 《大 西洋 月 刊 X7The 4tlantic Monthly ) 上 发 表 的 一 篇 文章 ， 
通过 浓缩 精简 ， 重 新 发 表 在 《生活 》 杂 志 上 ， 并 将 这 篇 文章 最 终 取 名 为 《思维 之 际 》( 4s 
We May Think )， 文 中 描述 了 一 种 未 来 的 发 明 ， 这 项 发 明 可 以 帮助 科学 家 和 研究 人 员 更 轻 
松 地 处 理 日 益 增 多 的 技术 期 刊 及 文章 。 布 什 提出 可 以 利用 微缩 胶片 作为 解决 方案 ， 同 时 
他 构想 出 了 一 种 叫做 麦克 斯 储存 器 ( Memex， 又 名 记忆 扩展 器 ) 的 设备 ， 它 可 以 对 书籍 、 
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文章 、 录 音 和 图 片 进 行 保存 。 麦 克 斯 储存 器 还 有 一 项 重要 的 功能 ， 那 就 是 它 可 以 让 用 户 


根据 某 个 主题 在 所 有 的 素材 之 间 建 立 起 关联 ， 这 些 关 联 的 基本 来 源 就 是 我 们 人 类 的 思维 。 


他 还 大 胆 预 言 一 种 新 的 职业 群体 ， 他 们 的 工作 就 是 在 繁杂 的 信息 载体 之 间 提 和 炼 并 建立 起 


可 靠 的 关联 。 


在 20 世纪 的 那个 年 代 ， 讲 述 辉 煌 未 来 的 文章 懂 见 不 鲜 ， 但 《思维 之 际 》 这 篇 文章 却 


异常 次 眼 。 它 所 讲述 的 不 是 可 以 蔡 代 我 们 去 做 家 务 劳 动 的 设备 ， 也 不 是 关于 未 来 运输 方 


式 或 智能 机 器 人 的 故事 ， 这 个 故事 的 主角 是 信息 〈Information )， 故 事 的 主线 是 如 何 利用 
新 技术 成 功 的 处 理 信息 。 


回顾 历史 ， 从 第 一 台 继 电器 计算 器 出 现 到 现在 为 止 ，65 年 过 去 了 ,计算 机 的 体积 越 
来 越 小 ， 处 理 速 度 越 来 越 快 ， 价 格 也 越 来 越 便宜 。 这 一 趋势 极 大 地 改变 了 计算 的 原始 属 


性 。 当 计算 机 价格 变 得 很 便宜 ， 可 以 实现 人 手 一 台 ; 当 计 算 机 体积 越 小 、 处 理 速度 越 快 ， 


软件 就 能 发 挥 更 大 的 作用 ， 而 机 器 就 可 以 承担 越 来 越 多 的 工作 。 


要 充分 利用 日 益 增长 的 运算 和 处 理 能 力 , 较 好 的 一 种 方法 就 是 不 断 改进 计算 机 系统 中 


的 关键 部 位 ， 最 


和 与 计算 机 是 两 种 完全 不 同形 式 的 “客观 存在 "， 只 可 惜 在 人 机 交互 的 这 个 过 程 中 ， 与 其 


型 的 就 是 用 户 界面 (User Interface ) 一 一 它 可 以 看 作 入 机 交互 的 轴 心 。 


让 计算 机 去 适应 人 类 的 特性 ， 远 不 如 劝 服 人 们 进行 调整 以 适应 计算 机 的 特性 来 得 容易 。 

在 计算 机 发 展 早期 ,交互 式 这 个 概念 并 没有 它 的 实际 意义 。 和 人 入 们 编程 时 更 多 使 用 的 
是 开关 和 电缆 ， 有 一 部 分 人 使 用 的 是 打 孔 纸 带 或 胶片 。 到 了 20 世纪 50 到 60 年 代 ( 有些 
观点 认为 这 一 时 间 可 以 延续 到 70 年 代 )， 计 算 机 已 经 可 以 使 用 批 处 理 (batch processing ) 


进行 编程 : 程序 和 数据 被 “分 布 ” 在 打 孔 卡 上 ， 然 后 一 次 性 录入 到 计算 机 内 存 。 这 些 工 


作 完 成 之 后 ， 再 | 


程序 对 数据 进行 分 析 ， 得 出 结论 ， 最 后 将 结果 打印 在 纸 上 。 


最 早 的 交互 式 计算 机 运用 的 是 电 传 打字 机 。 我 们 回忆 一 下 前 面 讲 过 的 达 特 茅 斯 
( Dartmouth ) 时 分 操作 系统 (原型 出 现 于 20 世纪 60 年 代 早期 ) 这 种 系统 支持 多 个 电 传 


打字 机 同时 工作 ， 


应 地 输出 一 行 或 多 行 。 通 常 ， 打 字 机 和 计算 机 之 间 的 信息 交流 是 由 一 串 ASCI 码 (也 有 


而 且 互 不 影响 。 此 类 系统 中 ， 用 户 在 打字 机 上 输入 一 行 ， 计 算 机 会 相 


可 能 是 其 他 字符 集 ) 来 完成 的 ， 这 些 ASCIH 码 大 多 由 字符 编码 组 成 ， 当 然 还 包括 像 回 车 、 


换行 等 一 系列 简 生 


的 控制 字符 编码 。 随 着 机 器 的 运行 ， 相 应 的 事务 也 随 着 打印 纸 的 旋转 


逐步 推进 。 
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一 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 


阴极 射线 管 (cathode-ray tube，CRT， 这 是 20 世纪 70 年 代 随 处 可 见 的 设备 ) 并 不 受 
这 类 限制 。 使 用 软件 来 协调 整个 屏幕 显得 更 加 灵活 方便 一 一 这 可 以 算得 上 是 一 种 二 维 的 
信息 平台 。 但 是 为 了 尽量 保持 操作 系统 显示 输出 的 逻辑 一 致 性 ， 早 期 那些 为 小 型 计算 机 
编写 的 软件 都 把 CRT 显示 器 看 做 “玻璃 屏幕 电 传 打 字 机 ”一 所 有 内 容 都 是 一 行 一 地 显 
示 的 ， 当 字符 排 到 底 端 ， 屏 幕 被 填 满 时 ， 屏幕 上 的 内 容 要 整体 向 上 翻滚 。 除 了 CP/M ( 微 
处 理 机 操作 系统 ) 中 的 所 有 工具 软件 之 外 ， 大 部 分 MS-DOS 下 的 工具 软件 都 采用 这 种 方 
法 一 一 它们 都 仿照 电 传 打字 机 的 工作 方式 来 使 用 视频 显示 器 。 使 用 电 传 打 字 机 这 种 工作 原 
理 的 操作 系统 有 很 多 ， 或 许 UNIX 才 算 是 最 典型 的 原型 操作 系统 之 一 ， 它 还 一 直 保留 着 


不 巧 的 是 ，ASCII 码 字 符 集 不 完全 适用 于 阴极 射线 管 的 工作 方式 。 在 最 原始 的 ASCII 
码 设计 中 , 编码 1Bh 被 标识 为 Escape, 它 的 主要 作用 是 帮助 字符 集 进行 扩充 。 在 1979 年 ， 
美国 国家 标准 协会 (American National Standards Institute，ANSI ) 发 布 了 一 -项 题 为 “ASCII 
人 码 使 用 的 附加 控制 (Additional Controls for Use with American National Standard Code for 
Information Interchange ) 的 标准 。 该 标准 发 布 的 初 襄 是 为 了 “适应 二 维 字 符 -图 像 设 备 输 
入 /输出 控制 中 迫在眉睫 的 相关 需求 , 其 中 包括 阴极 射线 管 和 打印 机 之 间 的 交互 终端 ……” 


其 实 Escape 的 编码 1Bh 只 占据 一 个 字 节 ， 且 它 的 含义 是 唯一 的 。Escape 如 果 作 为 一 
串 序 列 的 前 缀 字符 ， 那 么 这 串 字 符 序 列 的 含义 也 随 之 改变 。 比 如 下 面 这 串 序 列 : 


1Bh 58h 32h 4Ah 

可 以 看 出 Escape 编码 随后 紧 跟 的 是 字符 “[”“2”“J” 的 ASCII 码 , 现在 这 一 串 字 符 
的 含义 为 “ 清 屏 ”然后 移动 光标 至 左上 角 。 这 种 定义 在 电 传 打字 机 上 是 不 可 能 出 现 的 。 
下 面 这 串 序 列 : 


1Bh 5Bh 35h 3Bh 32h 39h 48h 
即 Escape 编码 随后 紧 跟 的 是 字符 “[”"、“5”、“;”、“2”、“9”、“H”， 这 串 字 符 的 作用 是 把 
光标 移 到 第 5 行 的 第 29 列 。 
键盘 和 CRT 一 起 对 远程 计算 机 传输 来 的 ASCII 码 ( 可 能 还 包括 Escape 字符 序列 ) 做 
出 响应 ， 这 种 设备 我 们 称 之 为 哑 终 端 (dumb terminal )。 哑 终端 相对 于 电 传 打字 机 速度 要 
更 快 ， 从 某 种 程度 来 讲 也 更 灵活 ， 但 从 速度 的 提高 程度 上 来 讲 ， 并 不 足以 引领 用 户 界 面 
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的 革新 。 真 正 的 革新 出 现在 20 世纪 70 年 代 小 型 计算 机 中 一 一 它 类 似 于 第 21 章 我 们 构建 
的 假想 计算 机 ， 配 备 了 “视频 显示 存储 器 "， 并 作为 微 处 理 器 地 址 空间 的 组 成 部 分 。 


第 一 个 预示 着 家 用 计算 机 将 与 它 的 挛 生 兄弟 一 一 体积 庞大 、 价 格 昂贵 的 大 型 机 划分 界 
限 的 标志 性 的 事件 是 VisiCalc 的 使 用 。VisiCalc 由 丹 .布莱克 林 (Dan Bricklin, 生 于 1951 
年 ) 和 鲍 勃 .弗兰克 斯 顿 (Bob Frankston， 生 于 1949 年 ) 设计 并 编程 实现 ， 而 这 套 系统 
于 1979 年 引入 苹果 开 型 电脑 (Apple I ) 中 。VisiCalc 通过 屏幕 将 一 个 二 维 电 子 数据 表 呈 
现 给 用 户 。 在 VisiCalc 出 现 之 前 , 数据 表 就 是 一 张 划 分 好 了 行 、 列 的 纸 ， 主要 用 于 一 系列 
计算 。VisiCalc 用 视频 显示 器 将 纸 质 材料 取而代之 , 通过 这 种 方式 ， 用 户 可 以 在 数据 表 中 
随处 游 走 ， 在 相应 位 置 输入 数据 、 公 式 ， 并 在 修改 后 对 结果 进行 重新 计算 ,为 用 户 提供 
了 更 多 的 自由 。 


令 我 们 惊讶 与 无 奈 的 是 , VisiCalc 这 款 应 用 程序 无 法 在 大 型 机 上 运行 。 因 为 像 VisiCalc 
这 类 程序 需 和 要 以 较 快 的 度 不 断 更 新 屏幕 , 所 以 , 它们 直接 将 数据 写 入 Apple TI 视频 显示 
器 所 配备 的 RAM 中 。 该 RAM 是 微 处 理 器 地 址 空间 的 一 部 分 。 大 型 时 分 计算 机 以 及 哑 终 
端 之 间 的 接口 速度 过 慢 ， 以 至 于 电子 报表 程序 无 法 使 用 。 


计算 机 对 键盘 的 响应 速度 越 快 ， 对 视频 显示 器 的 更 新 速度 越 快 ， 则 人 机 交互 就 越 频 
繁 。 在 IBM PC 刚刚 推出 的 10 年 里 ( 即 20 世纪 80 年 代 ), 几乎 搭配 的 所 有 软件 都 是 直接 
将 输出 的 数据 写 入 视频 显示 存储 器 的 。 当 时 IBM 建立 了 一 套 硬件 标准 ， 其 他 硬件 制造 商 
参照 这 些 标 准 去 生产 ， 这 样 软件 制造 商 就 可 以 绕 过 操作 系统 直接 操控 硬件 ， 统 一 化 的 硬 
件 标 准确 保 了 程序 的 正确 运行 (同时 也 杜绝 了 不 能 运行 的 情况 )。 如 果 所 有 同 构 的 PC 都 
拥有 异 构 的 视频 显示 器 硬件 接口 ， 这 种 做 法 无 异 于 将 软件 厂商 推 到 了 火 坑 里 ， 因 为 做 软 
件 的 同时 还 要 关注 硬件 设计 细节 是 不 现实 的 。 


IBM 早期 PC 配备 的 应 用 程序 通常 只 有 字符 输出 ， 很 少 有 图 形 输出 。 使 用 文本 输出 
大 大 加 快 了 应 用 程序 的 运行 速度 。 假 设 PC 上 配备 一 台 第 21 章 所 描述 的 视频 显示 器 ， 那 
么 程序 所 要 做 的 就 是 把 字符 相应 的 ASCI 码 写 入 内 存 ， 然 后 屏幕 上 就 会 显示 出 该 字符 。 
但 是 如 果 使 用 的 是 图 形 视频 显示 设备 ， 那 么 相应 的 程序 需要 将 8 个 或 更 多 的 字 节 写 入 到 
内 存 中 ， 这 样 做 的 目的 就 是 画 出 字符 的 外 观 并 以 图 形 的 方式 显示 。 


在 计算 机 的 发 展 史上 ， 从 字符 显示 到 图 形 显示 是 一 次 伟大 的 变革 ， 计 算 机 在 这 次 变 
革 中 迈 出 了 重要 的 一 步 。 然 而 ， 相 对 于 显示 文本 和 数字 所 采用 的 软 硬 件 ， 图 形 化 计算 机 
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的 软 硬 件 发 展 十 分 缓慢 。 早 在 1945 年 ， 约 翰 . 冯 : 诺 伊 曼 (John von Neumann ) 就 预见 
了 一 种 类 似 示波器 的 显示 器 ， 它 的 最 大 特点 是 可 以 显示 图 像 化 信息 。 但 直到 20 世纪 50 
年 代 早期 ，MIT ( 当时 得 到 了 IBM 资助 ) 建立 了 林肯 实验 室 ， 实 验 室 的 主要 任务 就 是 帮 
助 美国 空军 开发 一 种 适用 于 防空 系统 的 计算 机 ， 这 次 项 目 使 计算 机 的 图 形 化 成 为 现实 。 
该 项 目 被 称 为 半自动 地 面 防 空 系 统 ， 简 称 SAGE ( Semi-Automatic Ground Environment )， 
项 目的 内 容 包 括 构 建 一 个 显示 图 形 的 屏幕 ， 以 此 来 帮助 操作 员 分 析 海 量 数 据 。 


早期 的 视频 显示 器 , 比如 SAGE 中 使 用 的 这 一 种 显示 器 , 与 我 们 今天 所 使 用 的 PC 配 
套 显示 器 不 尽 相同 。 我 们 日 常 所 用 的 PC 配套 的 纯 平 显示 器 属于 光栅 (raster ) 显示 器 。 它 
的 原理 就 像 电视 机 ， 每 一 幅 图 像 背 后 都 是 一 行 行 的 光栅 线 ， 这 些 光 椰 是 电子 枪 ( electron 
gun ) 发 出 光束 迅速 来 回 移动 覆盖 整个 屏幕 而 形成 的 。 我 们 可 以 把 屏幕 想象 成 一 个 巨大 的 
矩形 阵列 ， 阵 列 的 每 个 元 素 都 是 一 个 点 ， 这 些 点 称 为 像素 (pixels )。 在 计算 机 内 部 ， 有 一 
块 专门 供 视频 显示 器 使 用 的 内 存 区 域 ， 屏 幕 上 的 每 一 个 像素 点 由 1 个 或 多 个 比特 表示 。 
这 些 二 进 制 数值 不 仅 决定 了 像素 点 的 亮度 ， 还 决定 了 它 的 颜色 。 


举例 来 讲 ， 当 今 大 多 数 计算 机 显示 器 的 水 平分 辨 率 至 少 为 640 个 像素 值 ， 垂 直 分 辩 
率 至 少 为 480 个 像素 ,像素 总 和 即 两 数 之 乘积 307,200。 如 果 为 每 个 像素 赋予 1 比特 内 
存 空 间 ， 这 时 每 个 像素 点 只 能 有 两 种 颜色 ， 通 常设 置 为 黑 、 白 两 种 颜色 ， 比 如 可 以 设置 
让 0 代表 黑色 ，1 代表 白色。 这 种 视频 显示 器 需要 占据 307,200 比特 的 内 存 ， 换 算 过 来 就 
是 38,400 字 节 。 


由 于 要 用 到 的 颜色 数目 逐渐 增加 ， 为 了 表示 这 些 颜 色 ， 每 个 像素 所 需要 的 比特 越 来 
越 多 ， 显 示 适 配器 需要 配备 的 存储 器 容量 也 越 来 越 大 。 比 如 我 们 想 使 像素 点 具备 不 同 的 
灰 度 ， 那 么 可 以 提供 一 个 字 节 的 存储 空间 。 在 这 种 处 理 方式 下 ， 字 节 00h 代表 着 黑色 ， 
FFh 代表 着 白色 ， 两 者 之 间 的 值 代表 着 不 同 的 灰 度 。 , 

CRT 上 的 色彩 空间 由 三 个 电子 枪 产生 ， 每 一 个 电子 枪 分 别 产生 三 原色 中 的 一 种 , 包 
插 红 色 、 绿 色 、 蓝 色 ( 用 放大 镜 来 观察 电视 机 或 彩色 计算 机 屏幕 ， 你 可 以 清楚 地 看 到 ， 
每 一 幅 图 像 都 是 利用 许 许多 多 不 同 的 三 原色 组 合 显示 出 来 的 )， 红 绿 组 合 出 黄色 ， 红 蓝 组 
合 出 品 红色 ， 蓝 绿 组 合 是 青色 ,三 原色 组 合 出 白色 。 

在 最 简单 的 彩色 显示 适配器 中 ， 表 示 每 个 像素 点 需要 3 个 比特 。 最 直观 的 编码 方式 
就 是 每 一 种 原色 对 应 编码 中 的 1 位 。 
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i 


这 种 方案 可 能 只 适合 简单 的 类 似 卡 通 画 的 图 像 。 真 实 世 界 出 现 的 几乎 所 有 颜色 都 是 
由 红 、 绿 、 蓝 三 原色 的 不 同色 阶 (levels ) 组 合 而 成 的 。 如 果 为 每 个 像素 赋予 2 个 字 节 的 
存储 空间 ， 这 样 一 来 ， 可 以 给 每 一 个 原色 分 配 5 位 (1 位 保留 ) 存储 空间 ， 这 种 方法 可 以 
表示 出 红 、 绿 、 蓝 三 种 颜色 日 每 种 颜色 具备 32 种 不 同 的 色 阶 ， 这 样 算 下 来 总 共有 32,768 
种 不 同 的 颜色 。 这 种 模式 通常 称 做 高 彩色 ( high color ) 或 数 干 种 颜色 ( thousands of colors )。 


我 们 下 面 尝试 一 下 用 3 个 字 节 来 表示 一 个 像素 ,三 原色 中 的 每 一 种 各 占 一 个 字 节 。 这 
种 编码 模式 使 红 、 绿 、 蓝 各 自 呈 现 出 256 种 不 同 的 色 阶 ， 这 样 算 下 来 共有 16,777,216 种 不 
同 的 颜色 ， 这 种 方案 通常 叫做 全 彩色 full color ) 或 百 万 种 颜色 ( millions of colors )。 如 果 
视频 显示 器 的 分 辨 率 为 640x480， 即 水 平 640 像素 , 垂直 480 像素 , 将 像素 点 的 数量 乘 以 表 
示 每 个 像素 点 需要 的 字 节 数 可 以 得 到 ， 共 需要 921,600 字 贡 的 存 依 容量 ， 即 将近 1MB。 


每 个 像素 所 赋予 的 比特 数 有 时 也 称 做 色 深 (color depth ) 或 色彩 分 辩 率 ( color 
resolution )。 颜 色 数 与 单个 像素 被 赋予 的 比特 数 的 关系 如 下 : 


颜 色 数 =2 每 个 像素 所 赋 子 的 比特 数 


如 果 视 频 适 配 卡 配备 的 存储 器 容量 有 限 ， 那 么 它 的 最 大 色 深 或 色彩 分 辨 率 自然 而 然 
也 受到 约束 。 假设 有 一 个 配备 了 1 MB 存储 器 的 视频 适 配 卡 ,在 每 个 像素 被 赋予 3 个 字 节 
的 情况 下 分 辩 率 可 以 达到 640x480。 如 果 想 把 分 辩 率 提高 到 800x600， 存 储 器 就 不 足以 为 
每 个 像素 赋予 3 个 字 节 ， 必 须 缩减 到 用 2 个 字 节 来 表示 一 个 像素 。 


虽然 现在 来 看 在 显示 器 上 使 用 光栅 技术 似乎 是 很 自然 的 事情 ， 但 是 在 早期 ， 这 种 做 
法 并 不 可 行 ， 因 为 在 当时 看 来 ， 这 种 技术 需要 的 存储 器 空间 太 大 。 在 这 种 情况 下 SAGE 
视频 显示 器 应 运 而 生 ， 它 是 一 种 矢量 (vector ) 显示 器 ， 相 比 电视 机 ， 它 更 像 一 种 示波器 。 
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一 下 编码 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
. 


电子 枪 可 以 通过 电 驱 动 定 位 到 显示 器 任何 一 个 像素 点 上 ， 之 后 可 以 直接 画 出 直线 或 曲线 。 
由 于 屏幕 上 的 图 像 具 有 持久 性 ， 不 会 立即 消失 ， 这 样 就 可 以 利用 直线 和 曲线 形成 最 基本 
的 画面 。 


支持 光 笔 (light pen ) 是 SAGE 计算 机 的 一 大 特色 ， 操 作者 使 用 光 笔 可 以 改变 显示 器 
上 的 图 像 。 光 笔 这 种 设备 很 特殊 ， 从 外 观 上 来 看 是 一 端 连 有 电线 的 笔 。 如 果 使 用 与 之 配 
套 的 软件 ， 计 算 机 能 够 感知 到 光 笔 所 指 的 屏幕 位 置 ， 随 即 根据 光 笔 的 位 移 相 应 地 改变 图 
像 。 


光 笔 的 工作 原理 是 什么 呢 ? 如 果 是 第 一 次 看 到 它 , 即使 是 相关 领域 的 技术 专家 , 也 会 
感到 困惑 。 理 解 它 的 关键 在 于 光 笔 并 不 发 射 (emit ) 光一 一 它 所 做 的 是 检测 ( detect ) 光 。 
对 于 CRT (无 论 采 用 的 是 光栅 还 是 向 量 显示 技术 )， 电 子 枪 移动 控制 电路 有 两 个 最 重要 的 
功能 ， 第 一 个 功能 是 光 笔 一 旦 感知 到 电子 枪 射出 的 光 ， 系 统 需要 立即 做 出 反应 ; 第 二 个 
功能 是 系统 在 对 其 做 出 反应 的 过 程 中 ， 需 要 确定 出 光 笔 指向 的 屏幕 位 置 。 


伊 凡 . 苏 泽 兰 (Van Sutherland， 生 于 1938 年 ) 是 最 早 预见 到 了 计算 机 发 展 的 一 个 全 
新 领域 ， 即 交互 式 计算 的 人 之 一 。 在 1963 年 ， 他 演示 了 为 SAGE 计算 机 专门 开发 的 名 为 
“画板 ”( sketchpad ) 的 程序 。 画 板 不 仅 可 以 将 图 像 信息 存放 在 存储 器 中 ， 还 可 以 把 图 像 
在 屏幕 上 显示 出 来 。 你 还 可 以 使 用 光 笔 在 显示 器 上 画 出 图 像 并 进行 修改 ， 与 此 同时 ， 计 
算 机 会 对 光 笔 的 轨迹 一 直 进 行 跟踪 。 


还 有 一 位 早期 交互 式 计算 的 预言 家 , 那 就 是 道格拉斯 恩格尔 巴特 Douglas Engelbart， 
生 于 1925 年 )。 他 曾 阅 读 过 1945 年 万 布什 发 表 的 文章 《思维 之 际 》 巧合 的 是 ， 五 年 
之 后 他 开始 致力 于 研究 计算 机 界面 显示 的 新 方法 ， 并 为 之 奉献 毕生 精力 。20 世纪 60 年 代 
中 期 ， 当 恩格尔 巴特 在 斯 坦 福 研 究 所 ( Stanford Research Institute ) 工作 时 ， 他 重新 思考 并 
设计 了 输入 设备 ， 提 出 了 用 五 股 (five-pronged ) 键盘 作为 指令 输入 设备 〈 这 个 设备 并 未 
普及 )， 另 外 还 提出 了 一 种 配备 轮子 和 按钮 的 设备 ， 它 的 名 字 就 是 鼠标 (mouse )。 鼠 标 现 
在 已 经 在 全 世界 被 广泛 接受 ， 它 可 以 用 来 移动 屏幕 内 的 指针 ， 还 可 以 选择 屏幕 上 出 现 的 
对 象 。 

许多 在 早期 热衷 于 交互 式 图 形 计算 的 科学 家 但 这 里 并 不 包括 恩格尔 巴特 )， 他 们 不 


约 而 同 地 聚集 在 了 施乐 (Xerox ) 公司 ， 垃 运 的 是 ， 此 时 的 光栅 显示 器 已 经 变 得 经 济 实用 。 
施乐 公司 在 1970 年 建立 了 帕 洛 阿尔 托 研 究 中 心 (Palo Alto Research Center，PARC )， 中 
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心 的 主要 任务 之 一 就 是 协助 产品 开 


.最 著名 的 预言 家 应 该 算是 阿 伦 . 凯 (Alan Kay, 4 
一 篇 罗伯特 ' 海 因 莱 


胶 
计算 机 。 


PARC 着 手 的 第 一 个 大 的 工程 是 阿尔 托 (Alto )， 
年 。 从 那个 年 代 的 标准 去 看 ， 它 是 


FE 于 1940 和 


Ff 发, 以 此 来 加 快 公司 迈 入 计算 机 产业 的 步伐 。PARC 中 
FE )，14 岁 那 年 ， 阿 伦 ， 
医 因 ”〈(Robert Heinlein ) 撰写 的 故事 中 ， 读 到 了 万 : 布什 提出 的 微缩 
片 图 书馆 ， 阿 伦 : 凯 因 此 而 深 受 启发 ,不 久 他 构想 了 一 种 名 为 “Dynabook” 的 便携 式 


还 包括 一 个 三 按钮 的 鼠标 。 在 Alto 3 


的 处 理 器 


Alto 有 讨 


个 令 人 了 眼前 


开发 的 时 候 ，16 位 
将 近 200 个 集成 电路 组 成 。 


F 多 与 众 不 同 的 地 方 ， 视 频 和 


凯 在 


它 的 设计 和 制造 完成 于 1972-1973 
亮 的 产品 。 它 采用 落地 式 系统 单元 ， 
配备 16 位 处 理 器 、2 个 3 MB 的 磁盘 驱动 器 、128 KB 的 内 存 (最 多 可 扩充 到 512 KB )， 


芯片 微 处 理 器 还 未 


可 世 ， 所 以 它 


一 张 纸 一 一 8 英寸 宽 ，10 英和 


为 808， 算 下 来 
只 有 两 种 : 黑色 或 


通过 直接 对 视频 显示 存储 器 进行 写 操作 ， 软 件 可 以 在 屏幕 上 绘 


同 大 小 的 文本 显示 在 屏幕 上 。 用 户 可 以 通过 移动 鼠标 ， 媳 
以 与 屏幕 上 的 对 象 进行 交互 。 视 频 显 示 器 与 电 传 打字 机 在 很 多 方 


有 489,648 个 像素 。 


[EU o 它 采 用 


时 示 器 是 其 中 一 个 方 j 


。 屏 幕 的 大 小 和 形状 就 像 
光栅 成 像 技术 ， 水 平 像素 值 为 6006， 垂直 像素 值 


和 白色。 视频 显示 的 专 月 


机 顺序 响应 


20 世纪 70 颖 
中 可 以 容纳 多 个 程 


] 户 输入 并 按 行将 程序 输 
密度 的 信息 阵列 ， 它 还 可 以 作为 直接 的 用 


F 代 晚期 , Alto 所 搭配 的 程序 逐 浙 


序 并 同时 显示 在 屏幕 上 。Alto 


的 视频 图 


户 输入 源 。 


时 中 每 个 像素 占据 1 位 存储 空间 ， 即 每 个 像素 取 值 
存储 器 容量 为 64 KB， 占 用 处 理 器 的 地 址 空间 。 
图 或 将 不 同 字体 、 不 

屏幕 上 对 指针 进行 定位 ， 还 可 

面 不 尽 相同 ， 电 传 打 当 

上 ， 而 视频 显示 器 的 屏幕 可 以 看 做 二 维 空间 上 的 高 


吓 显 出 很 多 新 奇 有 趣 的 特点 。 比 如 窗口 


像 功能 使 得 软件 从 文本 的 束缚 


中 摆脱 出 来 ， 使 其 可 以 更 加 真实 地 反映 用 户 的 想法 。 图 形 对 象 ( Graphical objects， 比 如 


按钮 、 菜 单 ， 以 及 被 称 做 图 标的 小 图 


上 ) 成 为 用 


进行 选择 、 触 发 图 形 对 象 来 执行 程序 功能 。 


软件 的 内 涵 就 在 于 此 ， 它 的 意义 远 不 止 仅 有 的 ) 


软件 使 得 计算 机 所 涵盖 的 应 用 


户 接 


的 一 员 。 鼠 标 可 以 在 多 个 窗口 中 


j 户 接口 ， 还 包括 与 / 


] 户 的 亲密 耦合 。 


领域 变 得 更 广 ， 而 不 仅仅 局 限于 简单 的 数字 变换 。 软 件 之 


所 以 被 设计 出 来 ， 其 最 终 目 的 是 一 一 引用 道格拉斯 ， 恩格尔 巴特 在 1963 发 表 的 一 篇 著名 


论文 的 标题 


《为 了 扩展 人 类 的 智慧 》( For the Augmentation of Man's Intellect )。 
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PARC 在 Alto 这 个 项 目的 开发 成 果 预 示 着 图 形 用 户 界面 ( Graphic User Interface ,GUI ) 
登 上 了 历史 的 舞台 。 施乐 公司 并 没有 将 Alto 推 向 市 场 ( 价格 定位 3 万 美元 以 上 绰绰有余 )。 
从 10 年 之 后 的 今天 来 看 ， 当 时 的 Alto 应 该 被 包装 成 一 种 成 功 的 消费 产品 并 推 向 市 场 。 


1979 年 ， 斯 蒂 夫 . 乔布斯 ( Steve Jobs ) 带领 苹果 公司 代表 团 对 PARC 进行 了 访问 ， 
在 那里 的 所 见 所 闻 给 他 们 留 下 了 深刻 的 印象 。 而 他 们 却 花 费 了 三 年 多 的 时 间 才 推出 具有 
图 形 界 面 的 计算 机 ， 这 就 是 在 1983 年 1 月 推出 的 苹果 莉 萨 (Apple Lisa )， 可 惜 这 套 系统 
在 当时 并 不 被 看 好 。 而 一 年 以 后 推出 的 麦 金 托 什 机 ( Macintosh ) 却 大 获 成 功 。 


最 原始 的 Macintosh 机 配备 有 Motorola 68000 微 处 理 器 .64 KB 的 只 读 存 储 器 、128 KB 
的 随机 访问 存储 器 、 一 个 3.5 英寸 的 磁盘 驱动 器 ( 存储 容量 为 400 KB )、 一 个 键盘 、 一 个 
鼠标 和 一 个 视频 显示 器 ， 显示 器 水 平 像素 为 S12， 垂 直 像 素 为 342 ( 仅 为 9 英寸 的 CRT 对 
角 线 长 度 )， 像 素 总 量 为 175,104 个 。 每 个 像素 赋予 1 位 内 存 ， 只 能 显示 黑白 两 色 ， 这 种 
配置 约 占 22 KB 的 视频 显示 存储 器 。 


最 原始 Macintosh 机 硬件 方面 很 精巧 ,但 是 可 更 新 能 力 很 差 。1984 年 Macintosh 操作 
系统 的 诞生 对 于 Mac ( 即 Macintosh 机 ) 意义 非凡 ， 它 的 由 现 使 得 Mac 变 得 与 众 不 同 ， 
当时 我 们 把 这 样 一 个 操作 系统 称 为 系统 软件 (System Software )， 它 就 是 现在 著名 的 苹果 
操作 系统 (Mac OS )。 


基于 文本 的 单 用 户 操作 系统 , 如 CP/M 或 MS-DOS, 体积 很 小 但 是 不 支持 扩展 的 应 用 
程序 接口 《API )。 关 于 这 点 在 第 22 章 进行 过 解释 ,在 这 些 基于 文本 的 操作 系统 中 ,没有 
为 访问 文件 系统 的 应 用 程序 提供 一 种 渠道 。Mac OS 这 种 图 形 化 操作 系统 所 占 的 空间 比 前 
面 提 到 的 这 两 种 要 大 得 多 ,其 中 包含 了 上 百 个 API 函数 ， 每 一 个 函数 都 用 其 功能 来 命名 。 


MS-DOS 操作 系统 是 基于 文本 的 ， 如 果 要 在 屏幕 上 以 电 传 打字 机 方式 将 文本 显示 出 
来 , 使 用 几 个 简单 的 API 函数 即 可 , 但 对 于 Mac OS 这 种 基于 图 形 的 操作 系统 ,必须 提供 
一 种 在 屏幕 上 显示 图 像 的 途径 ， 程 序 通过 这 条 途径 对 图 像 进 行 显示 。 从 理论 上 来 讲 ， 一 
个 API 函数 完全 可 以 胜任 这 项 任务 ， 函 数 的 功能 就 是 设置 某 个 水 平和 垂直 坐标 下 的 像素 
” 的 颜色 。 但 在 实际 应 用 中 ， 这 种 方法 效率 较 低 以 至 于 严重 影响 到 了 图 像 显示 的 速度 。 


在 这 种 需求 下 ， 如 果 操 作 系统 可 以 提供 一 整套 图 形 编程 系统 ， 那 么 其 意义 是 重大 的 ， 
这 样 的 操作 系统 必须 包含 如 下 API 函数 : 画 线 、 画 和 抢 形 、 画 椭圆 (包括 圆 ) 以 及 画 出 文 
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25 图 形 化 革命 本 


本 。 其 中 ， 线 条 可 以 是 实 线 ， 可 以 是 虚线 ， 还 可 以 是 点 线 ; 矩形 和 椭圆 可 以 具备 不 同 的 
填充 模式 ; 字符 可 以 具备 不 同 字体 和 大 小 ， 还 可 以 具备 不 同 特效 ， 如 加 粗 和 下 画 线 等 。 
图 形 编程 系统 负责 规划 如 何 将 各 式 各 样 的 图 形 对 象 以 点 阵 集合 的 形式 表示 在 显示 器 上 。 


如 果 程 序 在 图 形 操作 系统 下 运行 ， 那 么 它们 在 显示 器 或 打印 机 上 画图 这 一 过 程 中 ， 
使 用 的 是 一 套 完全 相同 的 API。 正 因为 如 此 , 字 处 理 程序 在 屏幕 上 显示 出 的 文档 , 与 打印 
出 来 而 得 到 的 纸 质 文档 ， 看 上 去 非常 相似 。 这 种 特点 称 为 “所 见 即 所 得 ”( 简写 为 
WYSIWYG )。 这 是 喜剧 演员 弗 雷 普 . 威 尔 森 (Flip Wilson ) 在 扮演 杰 拉 尔 本 (Geraldine ) 
角色 中 的 一 甸 话 ， 这 名 话 也 成 了 计算 机 领域 的 一 个 经 典 口号 。 


图 形 用 户 界面 对 用 户 而 言 是 极 具 吸引 力 的 ， 其 中 一 个 重要 原因 就 是 不 同 的 应 用 程序 
使 用 着 大 致 相同 的 工作 原理 ， 并 且 影 响 着 用 户 的 使 用 经 验 。 这 样 一 来 操作 系统 就 承担 起 
了 支持 API 函数 的 重任 ， 而 应 用 程序 就 可 以 利用 这 些 API 函数 去 实现 用 户 界面 的 不 同 组 
件 ， 如 按钮 和 菜单 等 。GUI 不 仅 是 一 种 看 上 去 简洁 友好 的 用 户 环境 ， 对 于 程序 员 而 言 ， 
它 还 是 一 种 重要 的 开发 环境 。 程 序 员 在 开发 新 一 代用 户 界 面 的 时 候 可 以 不 用 从 底层 开始 
重新 编写 。 


其 实 早 在 Macintosh 问世 之 前 , 一些 公司 已 经 开始 着 手 为 IBM PC 及 其 兼容 机 创建 图 
形 操作 系统 。 这 两 种 工作 有 一 个 显著 的 不 同 : 苹果 公司 的 硬件 和 软件 都 是 由 苹果 公司 自 
己 设计 的 ， 因 此 开发 人 员 的 工作 更 加 轻松 。Macintosh 系统 软件 只 支持 一 种 类 型 的 磁盘 驱 
动 器 、 一 种 视频 显示 器 ,以 及 两 种 型 号 的 打印 机 。 而 IBM PC 的 图 形 操作 系统 开发 人 员 所 
面 对 的 是 许多 不 同 的 硬件 ， 操 作 系 统 与 不 同 的 硬件 之 闻 需 要 同时 兼容 。 


还 有 一 点 ， 虽 然 IBM PC 问世 的 时 间 (1981 年 ) 较 早 ， 但 MS-DOS 应 用 程序 已 经 在 
多 数 人 心中 根深 蒂 固 ， 人 们 不 愿意 放弃 它们 。 因 此 PC 的 图 形 操作 系统 必须 具备 一 个 重要 
的 特性 ， 那 就 是 新 的 操作 系统 应 该 可 以 直接 兼容 MS-DOS 应 用 程序 ， 就 好 像 MS-DOS 应 
用 程序 是 为 新 的 操作 系统 专门 设计 的 (Macintosh 不 兼容 Apple I 系列 软件 ， 因 为 它们 的 
微 处 理 器 型 号 不 同 )。 


在 1985 年 , 迪 示 多 科研 公司 ( Digital Research，CP/M 的 后 续 公司 ) 推出 了 图 形 环 境 
管理 器 ( Graphical Environment Manager，GEM ); VisiCorp (推出 Visilalc 软件 的 公司 ) 

推出 了 VisiOn; 与 此 同时 微软 公司 发 布 了 Windows 1.0 版 本 , 作为 一 匹 黑马 ， 当 时 它 也 被 
很 多 人 认为 将 会 成 为 “视窗 争夺 战 ”的 胜利 者 。 然 而 直到 1990 年 3 月 Windows 3.0 发 布 ， 
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Windows 才 真 正 受 到 大 众 瞩 日 。 星 星之 火 从 那 时 开始 粹 原 。 在 本 书 出 版 的 2000 年 , 约 90% 
的 小 型 计算 机 上 使 用 的 都 是 Windows 操作 系统 ,除了 外 观 上 的 不 同 ,Macintosh 和 Windows 
这 两 种 操作 系统 所 包含 的 API 也 有 着 天 壤 之 别 。 


从 原理 上 来 分 析 ， 除 了 图 形 显示 器 ， 图 形 操作 系统 与 文本 操作 系统 相 比 ， 对 硬件 支 
持 的 要 求 并 没有 太 多 不 同 。 从 理论 上 来 讲 甚至 硬盘 驱动 器 都 可 以 算是 多 余 的 : 比如 最 初 
的 Macintosh 没有 配备 ，Windows 1.0 也 不 需要 。 虽 然 大 家 都 认为 使 用 鼠标 操作 会 更 加 方 
便 ， 但 其 实 Windows 1.0 可 以 不 需要 鼠标 。 


有 一 点 很 容易 想到 ， 随 着 微 处 理 器 速度 越 来 越 快 ， 内 存 和 外 存 的 容量 越 来 越 大 ， 图 形 
用 户 界面 将 更 加 深入 人 心 。 图 形 操作 系统 将 会 支持 越 来 越 多 的 特性 ， 它 们 所 占 的 存储 空间 
也 将 越 来 越 大 。2000 年 左右 的 主流 图 形 操 作 系 统 通常 需要 200 MB 的 硬盘 空间 和 32 MB 以 
上 的 内 存 。 


在 图 形 操 作 系 统 中 ， 应 用 程序 几乎 都 不 使 用 汇编 语言 来 开发 。 就 拿 早期 的 几 款 操作 
系统 来 看 ，Pascal 是 Macintosh 下 的 主流 开发 语言 。 在 Windows 操作 系统 中 ，C 语言 一 统 
江湖 。 还 有 一 个 不 得 不 提 到 的 例子 ， 那 就 是 PARC 向 我 们 展示 的 一 种 全 新 的 方法 。 大 概 
从 1972 年 开始 ，PARC 的 研究 员 着 手 开始 研发 一 种 名 为 Smalltalk 的 语言 ， 这 种 语言 嵌入 
了 面向 对 象 程序 设计 思想 (Object-Oriented Programming )， 也 就 是 今天 的 OOP。 


从 传统 意义 上 来 讲 ， 高 级 程序 设计 语言 会 自然 而 然 地 区 分 出 代码 〈 比 如 以 set、for、 
站 这 样 的 关键 词 开头 的 语句 ) 和 数据 ， 即 变量 所 代表 的 数字 。 这 种 区 分 毫 无 疑问 来 自 于 
冯 ' 诺 依 曼 计 算 机 的 体系 结构 。 在 这 样 一 种 体系 结构 中 ， 只 有 两 种 元 素 ， 一 种 是 机 器 码 ， 
一 种 是 机 器 码 所 操作 的 数据 。 


在 面向 对 象 的 程序 设计 中 , 和 冯 . 庄 依 曼 计 算 机 的 体系 结构 所 不 同 的 是 , 对 象 ( object ) 
实际 上 是 代码 和 数据 的 组 合 。 在 对 象 内 部 ， 与 其 相关 联 的 代码 决定 了 数据 存在 的 意义 ， 
要 理解 数据 的 存储 方式 首先 需要 理解 代码 。 对 象 如 果 需 要 与 其 他 对 象 通信 ， 则 通过 发 送 
或 接收 消息 (message ) 来 实现 这 一 过 程 ， 比 如 一 个 对 象 可 以 通过 给 另 一 个 对 象 发 送 指令 
来 获得 相应 信息 。 


在 图 形 操作 系统 的 应 用 程序 开发 过 程 中 ， 面 向 对 象 语言 可 以 算得 上 是 一 种 很 不 错 的 
工具 ， 因 为 编程 人 员 处 理 屏 幕 上 的 对 象 〈《 如 窗口 和 按钮 等 ) 的 过 程 就 是 用 户 感知 屏幕 元 
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素 的 过 程 。 举 例 来 讲 ， 假 设 按钮 是 面向 对 象 语言 中 的 一 个 对 象 。 屏 幕 上 的 按钮 具备 一 定 
尺寸 和 位 置 ， 按 钮 上 可 以 显示 文本 或 小 图 标 ， 这 些 都 可 以 抽象 成 为 与 对 象 关 联 的 数据 。 
如 果 用 户 通过 键盘 或 鼠标 按 下 按钮 ， 系 统 就 会 向 按钮 对 象 发 送 一 个 表示 其 被 触发 的 消息 ， 
该 按钮 对 象 收 到 消息 后 就 会 调用 与 自身 关联 的 代码 进行 响应 。 


小 型 计算 机 上 最 流行 的 面向 对 象 语言 是 一 种 对 传统 的 类 似 于 ALGOL 语言 的 扩展 ，C 
和 Pascal 就 属于 此 类 。 由 C 扩展 的 面向 对 象 语言 就 是 赫赫 有 名 的 C++ 我们 可 以 回忆 一 
下 ， 两 个 加 号 放 在 一 起 等 价 于 C 语言 中 的 自 增 操作 )。C++ 的 核心 思想 大 部 分 来 自 于 贝尔 
电话 实验 室 (Bell Telephone Laboratories ) 的 页 尼 . 斯 特 劳 斯 特 卢 普 (Bjarne Stroustrup， 
生 于 1950 年 ), 最 开始 C++ 是 作为 一 种 转换 程序 , 它 可 以 把 编写 的 程序 转换 成 C 程序 (但 
是 转换 出 的 C 程 序 即 难看 又 难以 理解 ) 转 换 完成 之 后 的 C 程 序 可 以 像 普通 程序 一 样 编译 。 


其 实 ， 面 向 对 象 语言 能 做 到 的 ， 传 统 语言 也 能 做 到 。 但 是 编程 终究 是 人 类 发 明 的 一 
种 解决 问题 的 活动 ， 面 向 对 象 语 言 使 得 编程 人 员 多 了 一 种 可 选 的 解决 方案 ， 这 种 解决 方 
案 具 备 更 加 优越 的 组 织 结构 。 如 果 你 想 一 一 虽然 困难 重重 一 一 面向 对 象 语 言 编写 的 一 种 程 
序 ， 并 使 其 在 Macintosh 和 Windows 上 都 可 以 编译 后 运行 ， 这 是 完全 可 以 做 到 的 。 此 类 
程序 并 不 直接 引用 API, 使 用 的 是 被 称 为 API 函数 的 对 象 。Macintosh 和 Windows 使 用 两 
种 不 同 的 对 象 定 义 来 编译 程序 。 


许多 在 小 型 计算 机 上 工作 的 编程 人 员 已 经 逐渐 不 用 命令 行 编译 程序 ， 而 是 使 用 集成 
开发 环境 (Integrated Development Environment，IDE )。 这 个 环境 里 集成 了 所 有 需要 的 工 
具 ， 而 环境 本 身 可 以 像 其 他 图 形 应 用 程序 一 样 运行 ， 这 样 一 来 就 大 大 简化 了 程序 开发 任 
务 。 还 有 一 种 称 做 可 视 化 编程 (Visual Programming ) 的 技术 被 程序 开发 人 员 广 泛 利用 ， 
按钮 及 其 他 组 件 可 以 通过 鼠标 拖 电 进行 “排版 "， 从 而 达到 在 窗口 交互 设计 的 目的 。 


在 第 22 章 中 我 们 一 起 讨论 过 文本 文件 。 为 了 方便 人 们 阅读 ， 这 类 文件 仅 由 ASCI 字 
符 组 成 。 我 们 回想 一 下 使 用 基于 文本 的 操作 系统 的 那个 年 代 ， 文 本 文件 是 应 用 程序 之 间 
进行 交流 的 理想 媒介 。 它 的 最 大 优点 是 可 检索 性 一 一 程序 可 以 检索 多 个 文本 文件 , 然后 确 
定 它们 中 是 否 有 文件 包含 某 一 字符 串 。 但 如 果 操 作 系统 中 有 一 种 机 制 用 来 显示 不 同 字体 、 
大 小 ， 以 及 不 同 效 果 比 如 斜体 、 黑 体 和 下 画 线 ， 那 么 文本 文件 就 不 再 适用 了 。 很 多 字 处 
理 软件 其 实 都 会 使 用 一 种 自己 独 有 的 二 进 制 格式 来 存储 文档 。 文 本 文件 同样 也 不 适用 于 
图 形 信息 。 
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2 编码 一 一 隐匿 在 计算 机 软 硬 件 背后 的 语言 
这 


但 我 们 要 清楚 的 是 ,与 文本 相关 的 信息 (比如 ,字体 及 段落 版 式 ) 都 可 以 被 编码 ， 而 
且 编 码 后 并 不 影响 其 可 读 性 。 这 种 方案 的 关键 是 选用 一 个 适当 的 转换 字符 来 标识 出 这 些 信 
息 。 在 Microsoft 设计 的 富 文本 文件 格式 (rich text format，RTF ) 中 ， 大 括号 “{” 和 “}” 
以 及 反 斜 杜 “\” 封 装 了 文本 的 格式 信息 ，RTF 也 成 为 了 应 用 程序 间 传 递 格式 化 文本 的 一 种 
方法 。 


PostScript 作为 一 种 文本 格式 ,将 这 种 概念 发 挥 到 了 极致 PostScript 的 设计 者 是 Adobe 
系统 的 创始 人 之 一 一 一 约翰 - 沃 诺 克 ( John Warnock， 生 于 1940 年 )。PostScript 是 一 种 通 
用 的 图 形 编 程 语言 , 在 2000 年 时 主要 用 在 高 端 计算 机 的 打印 机 上 , 用 于 显示 字符 或 图 形 。 


随 着 硬件 性 能 逐渐 提升 ， 价 格 日 渐 便 宜 ， 图 形 显 示 与 个 人 计算 环境 的 融合 已 是 大 势 
所 趋 。 微 处 理 器 的 处 理 速度 越 来 越 快 ， 存 储 器 价格 越 来 越 低廉 ， 视 频 显 示 器 及 打印 机 分 
辨 率 不 断 增加 ， 而 且 支持 的 颜色 数目 也 成 二 上 万 ， 这 一 切 大 大 推动 了 计算 机 图 形 界 发 展 。 


计算 机 图 形 也 逐步 产生 了 两 种 分 支 一 一 本 章 的 前 面 曾 提 到 过 这 两 个 词 , 当时 是 为 了 区 
分 图 形 视频 显示 器 一 一 这 两 个 分 支 就 是 矢量 和 光栅 。 

矢量 图 形 ( vector graphics ) 在 一 些 算法 的 帮助 下 ， 利 用 直线 、 曲 线 及 填充 区 域 生成 
图 形 。 这 也 正 是 计算 机 辅助 设计 ( Computer-Assisted Drawing，CAD ) 所 应 用 的 领域 。 矢 
景 图 形 在 工程 和 体系 结构 设计 中 有 着 十 分 重要 的 作用 。 矢 量 图 形 一 般 转 化 为 图 元 文件 
( metafile ) 格式 以 存放 到 文件 中 。 图 元 文件 是 由 生成 矢量 图 形 的 一 系列 绘制 命令 的 集合 组 
成 的 ， 这 些 命 令 通 常 已 经 被 编码 为 二 进 制 形 式 。 


量 图 形 的 主要 工具 就 是 直线 、 曲 线 及 填充 区 域 。 如 果 你 想 设 计 桥 梁 ， 使 用 矢量 图 
形 来 实现 将 很 简单 ， 但 如 果 要 显示 桥梁 的 实际 结构 ， 矢 量 图 形 就 显得 无 能 为 力 了 。 对 于 
现实 世界 里 的 一 副 桥梁 的 整体 结构 图 ， 用 矢量 图 形 来 表示 将 会 很 复杂 ， 而 且 困 难 重 重 。 


光栅 图 形 ( 也 称 做 位 图 )， 就 是 为 了 解决 这 一 问题 应 运 而 生 的 。 位 图 ( bitmap ) 将 图 
像 以 垂 阵 阵列 的 形式 进行 编码 ， 阵 列 中 的 一 个 单位 对 应 着 输出 设备 上 的 一 个 像素 点 。 就 
像 视频 显示 器 一 样 ， 位 图 是 一 种 空间 上 的 概念 〈 可 以 称 其 具有 分 辩 率 )， 其 图 像 的 宽度 和 
高 度 都 以 像素 为 单位 来 表示 。 位 图 也 具备 色 深 (也 可 叫做 颜色 分 辨 率 / 颜 色 深度 ) 的 概念 ， 
色 深 是 指 每 一 个 像素 被 赋予 的 比特 数 。 位 图 中 每 个 像素 被 赋予 的 比特 数 相同 。 


尽管 位 图 从 表现 形式 上 看 是 二 维 的 , 但 其 本 身 的 存储 形式 却 是 一 串 连 续 的 字 节 一 一 通 
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常 从 最 顶端 1 行 像素 开始 ， 紧 跟着 的 是 第 2 行 、 第 3 行 ， 等 等 。 


有 些 位 图 产生 于 图 形 操作 系统 设计 的 绘制 程序 ， 它 们 都 是 由 某 个 操作 者 利用 这 些 程 
序 “ 手 工 绘制 ”出 来 的 ， 还 有 一 些 位 图 是 由 计算 机 代码 通过 某 种 算法 产生 的 。 如 今 很 多 
现实 中 的 场景 都 利用 位 图 来 表示 (比如 数码 照片 ), 要 把 现实 世界 的 图 像 输 入 到 计算 机 中 ， 
可 以 借助 一 些 不 同 的 硬件 ， 这 类 设备 一 般 统称 为 电荷 炮 合 器 charge-coupled device， 
CCD )， 它 是 一 种 在 光照 下 会 起 电 的 半导体 器 件 。 每 个 像素 都 需要 一 个 CCD 单元 来 进行 


这 些 设备 中 最 原始 的 可 以 算是 扫描 仪 (scanner ) 了 ， 其 原理 和 影印 机 类 似 ， 都 是 利 
用 一 行 CCD 扫 过 需要 复印 的 图 像 的 表面 ， 比 如 照片 。 由 于 光 感 度 不 同 ， 不 同 区 域 CCD 
累积 的 电荷 数 也 不 同 。 扫 描 仪 的 配套 软件 把 图 像 转换 成 位 图 存放 在 文件 中 。 


视频 摄像 机 利用 二 维 CCD 单元 阵列 捕 挫 图像。 通常 被 捕捉 到 的 图 像 存放 在 录像 磁带 
上 。 但 其 实 视频 输出 可 以 直接 交 给 视频 帧 采集 器 〈 video frame grabber ) 去 处 理 ， 它 的 工 
作 原 理 是 把 模拟 信号 转换 成 像素 值 阵 列 。 帧 采集 器 可 以 收集 通用 的 视频 源 ， 如 录像 机 
(Video Cassette Recorder，VCR ) 或 激光 影碟 机 (Laser Disc Player )， 甚 至 可 以 用 于 有 线 电 
视 机 机 顶 盒 。 


近 几 年 ， 数 码 相机 的 价格 已 逐渐 降低 到 了 家 庭 用 户 可 以 承担 的 水 平 ， 它 们 从 外 观 上 
来 看 和 一 般 相机 几乎 一 样 。 但 数码 相机 并 不 使 用 胶片 ， 而 是 使 用 CCD 阵列 来 捕捉 图 像 并 
直接 将 其 转移 到 相机 的 存储 器 中 ， 之 后 在 适当 的 时 候 转 储 至 计算 机 中 。 


图 形 操作 系统 通常 可 以 将 位 图 文件 以 某 种 格式 进行 存储 。Macintosh 系统 采用 Paint 
格式 ， 之 所 以 叫 这 个 名 字 是 参考 了 创建 这 种 格式 的 MacPaint 程序 ( Macintdsh 的 PICT 格 
式 同时 支持 位 图 和 矢量 图 形 , 而 且 是 它们 的 首选 格式 ) Windows 里 的 默认 的 格式 是 BMP ， 
位 图 文件 通常 以 它 作 为 扩展 名 。 

位 图 文件 可 能 很 大 ， 如 果 有 方法 可 以 让 它们 变 小 一 些 那 就 再 好 不 过 了 。 这 种 需求 催 
生 了 计算 机 科学 中 的 数据 压缩 ( Data Compression ) 这 一 全 新 领域 。 

假设 我 们 正在 处 理 一 幅 每 个 像素 占 3 位 的 图 像 ， 这 种 图 像 在 本 章 前 面 曾 讲 过 。 这 张 
图 片上 出 现 的 画面 是 一 片 天 空 、 一 栋 房 子 和 一 块 草坪 。 因 此 ， 图 片 中 可 能 有 大 片 的 蓝 色 
和 绿色 。 很 可 能 位 图 的 最 上 面 一 行 出 现 了 72 个 蓝 色 像素 。 如 果 有 一 种 方法 可 以 表示 蓝 色 
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像素 连续 上 重复 了 72 次 ， 那么 通过 这 种 方法 表示 的 位 图 文件 将 会 比 原先 的 小 很 多 。 这 样 
的 压缩 方法 称 为 游程 长 度 编码 (Run-Length Encoding )， 即 RLE。 


通常 办 公 室 的 传真 机 采用 的 就 是 RLE 压缩 方法 ， 上 压缩 过 程 一 般 在 传真 机 通过 电话 线 
传送 图 像 之 前 。 由 于 传真 机 展现 出 的 图 片 都 是 黑白 两 色 ， 没 有 灰 度 和 彩色 ， 所 以 通常 像 
素 值 都 会 有 很 长 串 的 白色 区 域 ， 适 合 使 用 RLE 压缩 。 


这 十 多 年 里 风光 无 限 的 位 图 文件 格式 是 图 形 交换 格式 ( Graphics Interchange Format ) 
即 GE， 由 计算 服务 (CompuServe ) 公司 于 1987 年 开发 。GIF 文件 所 采用 的 压缩 技术 称 
为 LZW，LZW 源 自 其 三 位 创建 者 的 名 字 : Lemplel、Ziv 和 Welch。LZW 比 RLE 更 加 强 
大 ， 因 为 它 所 考虑 的 是 像素 值 的 模式 (patterns )， 而 RLE 针对 的 是 具有 相同 值 的 像素 串 。 


RLE 和 LZW 都 属 无 损 (lossless ) 压缩 技术 范畴 ， 因 为 可 以 从 压缩 数据 中 重新 生成 完 
整 的 初始 文件 。 专 业 一 点 的 说 法 是 ， 压 缩 过 程 是 可 逆 的 (reversible )。 可 逆 压 缩 方法 并 不 
适用 于 所 有 类 型 的 文件 ， 这 点 不 难 证 明 。 在 某 些 情况 下 ， 采 用 这 些 方法 “压缩 ”后 的 文 
件 比 初始 文件 还 要 大 ! 


近 几 年 来 看 ， 有 损 (lossy ) 压缩 技术 大 行 其 道 。 有 损失 的 压缩 是 不 可 逆 的 ， 这 是 由 
于 部 分 原始 数据 在 压缩 过 程 中 被 丢弃 了 。 有 损 压缩 技术 不 应 该 用 于 电子 报表 或 文字 处 理 
文档 ， 因 为 在 这 些 重 要 文档 里 面 少 一 个 数字 或 者 字母 都 会 “ 失 之 毫 厘 ， 雇 以 干 里 ”。 但 对 
于 压缩 图 像 ， 这 些 损失 还 是 可 以 接受 的 ， 部 分 数据 的 损失 不 会 使 图 片 的 整体 效果 有 太 大 
的 变化 。 这 就 是 为 什么 有 损 压缩 技术 的 思想 起 源 于 心理 视觉 的 原因 ， 心 理 视觉 领域 所 探 
究 的 是 人 的 视觉 ， 并 根据 心理 因素 确定 人 们 所 看 到 的 景象 中 哪些 比较 重要 而 哪些 不 重要 。 


在 JPEG 中 ， 人们 使 用 了 一 系列 具有 重大 意义 的 位 图 有 损 压 缩 技术 ,。JPEG 代表 的 是 
联合 图 像 专家 组 ( Joint Photography Experts Group ), 它 涵盖 了 几 种 压 缩 技术 ,其 中 一 些 是 
无 损 的 ， 另 一 些 是 有 损 的 。 


把 图 元 文件 转换 成 位 图 文件 的 方法 很 简单 。 这 是 由 于 视频 显示 存储 器 与 位 图 在 概念 
上 保持 一 致 。 如 果 程 序 能 把 图 元 文件 画 在 视频 显示 存储 器 中 ， 则 它 也 能 在 位 图 上 画 出 图 
元 文件 。 


但 从 位 图 文件 到 图 元 文件 的 转换 却 不 那么 容易 ， 如 果 位 图 文件 过 于 复杂 甚至 会 导致 
无 法 转换 。 为 了 解决 此 类 问题 ， 人 们 发 明了 一 项 技术 ， 那 就 是 光学 字符 识别 〈《Optical 
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Character Recognition ), 或 简称 为 OCR。 对 于 位 图 上 出 现 的 一 些 字符 (来 自 于 传真 机 , 或 
来 自 于 页 面 扫描 )， 如 果 需 要 转换 成 ASCI 码 ， 那 么 OCR 就 会 派 上 用 场 。OCR 软件 会 对 
比特 流 进行 模式 识别 ， 然 后 确定 其 代表 的 字符 。 由 于 算法 的 复杂 性 ，OCR 软件 并 不 能 保 
证 百分之百 准确 。 昌 然 不 很 准确 ， 但 是 OCR 软件 一 直 尝 试 将 手写 的 字符 也 转换 成 ASCII 


位 图 和 图 元 文件 都 是 数字 化 的 可 视 信息 。 同 理 ， 音 频 信息 也 能 转换 成 比特 和 字 节 。 


随 着 1983 年 激光 唱片 ( compact disc ) 的 问世 ,数字 化 音响 掀起 了 一 轮 消费 狂潮 ， 它 
同时 也 成 为 了 最 成 功 的 电子 消费 品 案 例 。CD 是 由 飞利浦 和 索尼 公司 联合 开发 出 的 产品 ， 
一 张 直径 为 12 cm 的 CD 可 存储 74 分 钟 的 数字 化 声音 。 而 这 个 74 分 钟 的 时 长 因为 贝多 芬 
的 第 九 交 响 曲 (Beethoven's Ninth Symphony ) 刚好 可 以 存储 在 一 张 CD 上 。 


CD 中 声音 信息 采用 的 编码 技术 被 称 为 脉冲 编码 调制 技术 ( Pulse Code Modulation )， 
简称 为 PCM。 名 字 听 起 来 有 点 故弄玄虚 ， 但 从 概念 上 讲 PCM 其 实 是 一 种 很 简单 的 过 程 。 
振动 是 声音 之 源 。 人 们 发 出 的 声音 来 源 于 声带 的 振动 ， 大 号 的 声音 也 来 自 于 振动 ， 
森林 里 的 树 倒 下 的 声音 归根 结 底 也 是 振动 ， 还 有 很 多 例子 ， 它 们 的 振动 来 源 于 空气 分 子 
的 移动 。 空 气 在 被 推拉 的 过 程 中 ， 有 时 压缩 有 时 放松 ， 有 时 向 后 有 时 向 前 ， 这 个 过 程 每 
秒 钟 可 以 达到 成 百 上 干 次 ， 最 终 使 耳膜 产生 振动 ， 从 而 我 们 能 够 听 到 声音 。 


声波 可 以 被 模拟 ， 一 个 成 功 的 例子 就 是 1877 年 爱迪生 发 明 的 第 一 台电 唱机 ， 它 利用 
锡 箱 圆 桶 表面 上 的 隆起 和 凹陷 部 位 录制 和 播放 背景 音乐 。 直到 CD 的 出 现 , 这 种 录制 技术 
才 发 生 了 稍 许 变化 ， 圆 桶 变 成 了 光盘 ， 锡 箔 变 成 了 塑料 。 早 期 的 电 唱 机 是 机 械 化 的 ， 但 
是 后 来 ， 电 子 放大 器 被 用 来 放大 声音 。 声 音 可 以 通过 麦克 风 上 配备 的 可 变 电 阻 转换 成 电 
流 ， 喇 叭 中 的 电磁 铁 又 可 以 将 电流 转换 为 声音 。 


代表 声音 的 电流 与 先前 所 讲 过 信号 不 同 ,本 书 之 前 讨论 过 的 是 在 “连通 一 一 断 开 ” 之 
间 跑 变 的 0 数字 信和 号。 声波 的 变化 是 连续 的 ， 因 而 产生 电流 的 电压 也 是 如 此 。 在 这 里 电 
流产 生 的 目的 是 模拟 ( analog ) 声波 。 为 了 达到 这 个 目的 ， 我 们 使 用 了 一 种 新 设备 ， 通 常 
把 它 叫做 模拟 数字 转换 器 ( Analog To Digital Converter，ADC ) 一 一 所 有 的 功能 集成 在 了 
个 芯片 上 一 一 将 模拟 电压 转换 成 二 进 制 数 表示 。 一 定 长 度 的 数字 信号 将 会 被 ADC 所 输 
出 一 一 通常 长 度 为 8、12 或 16 个 比特 一 一 它们 组 合 在 一 起 表明 了 电压 的 相对 级 别 。 如 果 
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ADC 的 转化 长 度 为 12 比特 ， 那 么 电压 值 的 取 值 范围 为 000h ~ FFFh， 这 样 一 来 就 可 以 区 
分 出 4096 个 不 同 的 电压 级 别 。 


在 一 种 名 为 脉冲 编码 调制 (Pulse Code Modulation ) 的 技术 中 ， 以 电压 形式 表示 的 声 
波 将 以 恒定 的 频率 被 转换 成 数值 。 而 这 些 数值 将 以 小 孔 的 形式 刻 在 光盘 表面 ， 通 过 这 种 
方式 , 电压 就 以 数值 的 形式 被 存储 在 CD 上 。 要 读 取 这 些 信 息 时 , 可 以 通过 分 析 从 CD 表 
面 反 射 的 激光 读 取 到 所 存储 的 数值 。 在 播放 声音 的 时 候 这 些 数 值 又 被 转换 成 电流 ， 这 一 
过 程 利 用 到 了 数字 模拟 转换 器 (Digital-To-Analog converter， 即 DAC，DAC 还 可 以 用 在 
彩色 图 形 板 上 ， 将 像素 值 转换 成 模拟 信号 并 传输 至 显示 器 )。 


声波 电压 在 恒定 的 频率 下 被 转换 成 了 数字 ， 该 频率 被 称 为 采样 率 (sampling rate )。 
1928 年 ， 贝 尔 电 话 实验 室 的 哈里 ， 奈 奎 斯 特 (Harry Nyquist ) 通过 证 明 得 到 了 一 个 总 要 
结论 : 采样 频率 应 至 少 为 被 采样 信号 ( 即 被 记录 和 播放 的 信号 ) 最 大 频率 的 两 倍 。 人 类 
可 以 听 到 的 声音 的 频率 范围 通常 为 20 ~ 20,000Hz。CD 使 用 的 采样 频率 为 每 秒 44,100 次 ， 
比 人 类 听觉 范围 最 大 频率 的 两 倍 还 要 大 一 些 。 


CD 中 存储 的 声音 的 动态 变化 范围 决定 了 每 次 采样 的 比特 数 ， 这 个 范围 就 是 CD 存储 
声音 的 最 高 与 最 低频 率 之 差 。 这 难免 给 人 感觉 有 些 复杂 : 电流 通过 不 断 变化 来 模拟 声波 ， 
其 达到 的 最 高 峰 称 为 声波 的 振幅 ( amplitude )。 我 们 感知 到 的 声音 强度 是 振幅 的 两 倍 。1 
贝尔 (bel， 这 个 名 称 来 源 于 Alexander Graham Bell 最 后 一 个 单词 的 三 个 字母 )， 代 表 着 强 
度 的 10 倍 ; 1 分贝 (decibel ) 代表 着 1 贝尔 的 十 分 之 一 。1 分 贝 代表 着 人 类 所 能 感知 到 的 
声音 最 小 强度 变化 。 


如 果 每 次 采样 大 小 为 16 比特 ， 这 样 就 能 够 表示 96 分 贝 的 动态 范围 ， 这 一 范围 的 下 
限 是 刚好 能 听 到 的 声音 的 阔 值 〈《 低 于 这 一 值 的 声音 是 听 不 到 的 )， 而 上 限 就 是 人 们 承受 最 
大 负荷 声音 的 极限 阀 值 。CD 光盘 的 每 个 采样 点 就 是 用 16 比特 表示 的 。 


综 上 所 述 ，CD 光盘 中 每 秒 产生 44,100 个 采样 样本 , 每 个 样本 占据 2 个 字 节 。 有 时 你 
还 希望 享受 立体 声效 果 ， 这样 的 话 采 样 信息 需要 翻 倍 ， 则 每 秒 总 共 需 要 176,400 字 节 , 算 
下 来 每 分 种 需要 10,584,000 个 字 节 (这 是 个 庞大 的 数字 , 正 因 如 此 ，20 世纪 80 年 代 前 数 
字 记 录 声 音 的 方法 并 没有 普及 )。74 分 钟 的 立体 声 CD 需要 字 节 数 为 783,216,000。 


相对 于 模拟 声音 , 数字 化 声音 的 优点 不 言 而 喻 。 特别 是 在 模拟 声音 被 复制 的 时 候 ( 例 
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如 把 录音 磁带 转录 成 电 唱 片 ) 难免 会 有 些 失真 。 而 对 于 用 数字 形式 表示 的 数字 化 声音 而 
言 ， 都 可 以 实现 无 失真 的 转录 或 复制 。 细 心 观 察 的 人 会 发 现 ， 过 去 在 电话 通话 中 ， 信 号 
传输 线路 越 长 则 声音 越 糙 。 这 种 情况 已 经 一 去 不 复 返 了 ， 因 为 现在 大 部 分 电话 系统 都 已 
经 数字 化 了 ， 即 使 你 打 跨国 电话 ， 听 简 中 的 声音 也 像 在 对 街 对 话 一 样 清晰 。 


CD 可 以 存储 声音 , 也 可 以 存储 数据 。 专门 用 来 存储 数据 的 CD 统称 为 CD-ROM ( CD 
只 读 存 储 器 ), 通常 CD-ROM 最 大 存储 容量 约 为 660 MB。 如 今 许 多 计算 机 中 都 配备 CD 驱 
动 器 ， 而 应 用 程序 及 游戏 软件 都 可 以 存储 在 CD-ROM 中 。 


声音 、 音 乐 、 视 频 逐 渐 走 入 个 人 计算 机 是 在 大 约 10 年 前 ， 当 时 统称 为 多 媒体 
( multimedia )， 昌 然 这 几 年 发 展 很 迅速 ， 但 这 个 名 字 已 经 普遍 使 用 开 来 ， 所 以 也 就 不 需要 
新 起 一 个 特别 的 名 称 了 。 如 今 的 家 用 计算 机 都 配备 声卡 ， 声 卡 中 包含 一 个 ADC， 它 可 以 
将 麦克 风 传 输 的 模拟 声音 信号 转 储 成 为 数字 信号 ， 此 外 还 包括 一 个 DAC， 它 的 作用 是 帮 
助 扩 音 器 播放 录制 的 数字 声音 。 声 音 还 可 以 按照 波形 文件 ( waveform files ) 方式 存放 于 
磁盘 。 


在 我 们 使 用 家 用 计算 机 录制 和 播放 声音 的 时 候 ， 其 实 对 声音 质量 要 求 并 不 高 ， 一 般 
会 苛求 达到 CD 的 效果 , 所 以 Macintosh 和 Windows 这 两 种 操作 系统 提供 了 较 低 的 采样 
频率 ， 尤 其 是 22,050 Hz、11,025 Hz 和 8,000 Hz 这 三 种 频率 ， 采样 信息 量 也 保持 在 较 少 的 
8 位 , 并且 使 用 了 频 度 录制 手段 。 声音 录制 时 所 占 的 存储 容量 也 减少 到 了 每 秒 8000 字 节 ， 
这 样 算 下 来 每 分 钟 约 占 480,000 字 节 。 


很 多 人 在 科幻 电影 及 电视 剧 集中 看 到 过 这 样 的 场景 ， 未 来 的 计算 机 正在 用 纯正 的 英 : 
语 与 用 户 进行 交互 。 只 要 计算 机 配备 了 录制 和 播放 数字 化 声音 的 硬件 ， 那 么 实现 这 个 目 
标 不 过 是 一 个 软件 问题 。 | 


如 果 要 使 计算 机 能 够 用 易于 理解 的 单词 和 句子 与 人 交谈 ， 有 很 多 种 方法 。 一 种 方法 
是 预先 录制 句子 、 短 语 、 单 词 还 有 数字 ， 然 后 将 它们 以 文件 的 形式 存储 ， 之 后 使 用 多 种 
形式 将 其 帮 合 在 一 起 。 这 种 方法 常见 于 电话 公司 的 信息 系统 中 ， 在 这 种 环境 下 只 需要 有 
限 的 单词 、 数 字 及 其 组 合 ， 因 此 这 种 方式 能 适用 。 


有 一 种 更 加 通用 的 声音 合成 方法 ， 它 把 ASCII 码 字符 转换 成 波形 数据 。 例 如 在 英语 
拼写 方面 ， 由 于 存在 很 多 不 一 致 性 ， 软 件 系统 需要 使 用 一 个 词典 或 复杂 的 算法 来 确定 单 
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词 的 准确 发 音 。 一 个 完整 的 单词 由 基本 的 音节 《也 叫做 音素 ，phonemes ) 组 成 。 一 般 情 
况 下 软件 都 需要 做 一 些 其 他 方面 的 调整 。 如 果 一 个 句子 后 紧 跟 着 的 是 问号 ， 则 最 后 一 个 
单词 的 发 音频 率 必须 相应 提高 。 


语音 识别 (voice recognition ) 一 一 把 波形 数据 转换 成 ASCI 码 字 符 一 一 这 个 是 一 个 极其 
复杂 的 过 程 。 其 实 许多 人 在 理解 口语 化 的 方言 时 也 有 很 多 困难 。 在 使 用 个 人 计算 中 的 语 
音 处 理 软件 时 ， 通 常 需要 对 软件 进行 样本 训练 ， 以 便 软 件 能 尽量 准确 地 转录 某 个 人 的 话 
语 。 这 中 间 涉 及 的 问题 已 经 大 大 超出 了 ASCII 码 文本 转换 的 范畴 ， 从 本 质 上 来 讲 是 一 个 
利用 编程 技术 使 得 计算 机 “理解 ”人 类 语言 的 过 程 。 这 类 问题 正 是 人 工 智 能 ( artificial 
Intelligence ) 所 研究 的 领域 。 


当今 计算 机 中 的 声卡 还 配备 了 小 型 电子 音乐 合成 器 ， 它 能 模仿 128 种 不 同 的 乐器 和 
47 种 不 同 的 打击 乐器 ， 这 类 设备 被 称 做 MIDI 合成 器 。MIDI 即 乐器 数字 接口 (Musical 
Instrument Digital Interface )， 这 项 发 明 出 现 于 在 20 世纪 80 年 代 早 期 ， 由 一 家 电子 音乐 合 
成 器 制造 协会 推出 ， 主 要 用 于 将 电子 乐器 组 合 起 来 ， 并 且 连 到 计算 机 上 。 


MIDI 合成 器 的 类 型 不 同 ， 它 们 合成 乐器 声音 的 方法 也 就 不 同 ， 有 一 些 方法 的 效果 更 
加 逼真 。MIDI 合成 器 所 展现 出 来 的 特性 已 经 超越 了 MIDI 所 定义 的 范畴 。 但 其 实 它 的 功 
能 就 是 以 演奏 声音 的 方式 来 响应 短 消息 序列 一 一 长 度 通常 为 1]、2 或 3 个 字 节 。MIDI 消息 
本 身 就 指明 了 所 需要 的 乐器 、 将 要 演奏 的 音符 ， 或 正在 演奏 的 音乐 的 休止 符 。 


MIDI 文件 不 仅 包 含 了 一 系列 MIDI 消息 集合 ， 还 包括 了 时 间 人 信息。 通常 一 个 MIDI 
文件 “ 麻 从 虽 小 ， 五 脏 俱 全 ”"， 包 含 了 整套 演奏 信息 ， 因 此 可 以 由 计算 机 上 的 MIDI 合成 
器 完整 地 演奏 。 相 比 于 包含 同样 一 段 音乐 的 波形 文件 ，MIDI 文件 通常 要 小 得 多 。 就 文件 
的 相对 大 小 而 言 , 如 果 把 一 个 该 形 文件 比 作 位 图 文件 , 则 MIDI 文件 就 好 像 天 量 图 元 文件 。 
MIDI 文件 的 缺点 来 源 于 MIDI 合成 器 的 异 构 性 : 同样 一 个 MIDI 文件 可 能 在 一 个 合成 器 
上 完美 演奏 ， 但 在 另 一 个 合成 器 上 可 能 不 堪 入 耳 。 


数字 化 电影 是 多 媒体 的 另 一 片 天 地 。 把 一 系列 静止 图 像 快 速 播放 , 可 以 达到 电影 和 
电视 图 像 中 出 现 的 物体 移动 效果 。 我 们 把 这 期 间 出 现 的 单个 图 像 称 为 帧 〈 frames )。 电 
影 的 播放 速率 为 24 帧 / 秒 ， 北 美的 电视 节目 为 30 帧 / 秒 ， 世 界 上 大 部 分 地 方 的 电视 为 25 
帧 / 秒 。 
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计算 机 中 的 电影 文件 一 般 都 是 由 一 系列 附带 声音 的 位 图 组 合 而 成 。 但 是 如 果 不 经 过 
压缩 处 理 ， 一 部 电影 文件 中 的 数据 量 将 会 很 大 。 假 如 电影 中 每 一 帧 包含 的 像素 大 小 是 
640x480， 每 个 像素 为 24 位 真 彩色 ， 那 么 每 一 帧 的 大 小 就 为 921,600 字 节 。 如 果 播 放 速 度 
为 30 帧 / 秒 ， 则 每 秒 需要 的 存储 空间 为 27,648,000 字 节 。 照 这 样 计 算 下 去 ,每 分 钟 需要 的 
空间 大 小 为 1,658,880,000 字 节 ， 一 部 两 小 时 的 电影 需要 199,065,600,000 字 节 ， 大 约 200 
GB。 正 因 如 此 ， 我 们 的 计算 机 上 播放 的 电影 经 常 很 短 、 解 析 度 很 小 ， 而 且 清晰 度 很 差 。 


就 像 EPG 压缩 技术 可 以 用 来 减少 静态 图 像 所 占 的 数据 空间 一 样 , MPEG 压缩 技术 用 
于 处 理 动态 电影 文件 。MPEG 全 称 是 移动 图 像 专家 小 组 ( Moving Pictures Expert Group )。 
动态 图 像 压 缩 技 术 基 于 的 是 一 种 客观 事实 ， 即 每 一 帧 继承 了 前 一 帧 的 大 部 分 信息 ， 也 就 
是 说 存在 元 余 信息 。 


针对 不 同 的 多 媒体 产品 有 不 同 的 MPEG 标准 。MPEG-2 用 于 高 清晰 度 电 视 
( high-definition television，HDTYV ) 及 数字 影音 光盘 (digital video discs，DVD )。DVD 也 
叫 数字 多 用 光盘 〈digital versatile discs )， 其 物理 大 小 与 CD 一 样 ， 但 是 DVD 的 两 面 都 可 
以 记录 数据 而 且 每 一 面 有 两 层 。 在 DVD 中 , 视频 信息 可 以 压缩 为 原始 大 小 的 五 十 分 之 一 ， 
因此 前 面 提 到 的 一 部 两 小 时 的 电影 将 占据 4 GB 的 空间 , 而且 只 占据 其 中 一 面 的 一 层 。 所 
以 一 张 具 有 两 面 四 层 的 DVD 盘 容 量 可 达到 16 GB, 容量 达到 了 CD 的 25 倍 。 如 果 不 出 预 
料 ， 在 未 来 的 某 一 天 ，DVD 将 奉 代 CD-ROM 成 为 新 的 软件 存储 媒介 。 


随 着 CD-ROM 和 DVD-ROM 的 出 现 , 这 是 否 意味 着 万 .布什 预言 的 麦克 斯 储存 器 在 
今天 成 为 了 现实 ? 最 原始 的 麦克 斯 储存 器 设想 中 ， 使 用 的 原材料 是 缩微 胶片 ， 但 显然 
CD-ROM 和 DVD-ROM 更 合适 担 此 重任 。 由 于 电子 媒体 易于 检索 ， 它 们 比 物 理 媒体 更 具 
有 优越 性 。 可 惜 同时 访问 多 个 CD 或 DVD 驱动 器 并 不 现实 。 我 们 的 存储 设备 有 一 点 与 
万 布什 所 提出 的 概念 有 所 不 同 ， 那 就 是 所 有 信息 并 不 一 定 要 触手 可 及 ， 真 正 使 它们 达 
到 信息 共享 的 做 法 是 计算 机 互 连 ， 这 样 做 还 可 以 更 有 效 地 利用 存 情 空间 。 

对 计算 机 进行 公开 性 远程 操作 的 第 一 人 是 乔治 . 史 帝 比 兹 (George Stibitz )， 也 正 是 
他 , 在 20 世纪 30 年 代 设计 了 贝尔 实验 室 的 继电器 计算 机 。 对 继电器 计算 机 的 远程 操作 
的 演示 地 点 在 达 特 茅 斯 ， 时 间 是 在 1940 年 。 

电话 系统 在 线路 上 传输 的 是 声音 ， 而 不 是 比特 。 在 电话 线路 上 传输 比特 需要 先 将 其 
转换 成 声音 , 传输 完 之 后 在 转换 回 比特 。 单 一 频率 和 振幅 的 连续 声波 ( 统称 为 载波 , carrier ) 
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无 法 表达 完整 清晰 的 信息 。 但 如 果 对 声波 进行 一 些 调整 一 一 说 得 专业 一 点 就 是 , 对 声波 进 
行 调制 (modulate ) 使 其 反映 两 种 不 同 的 状态 一 一 通过 这 种 方式 可 以 表示 出 0 和 1。 将 比 
特 与 声波 进行 互相 转换 的 设备 被 称 做 调制 解 调 器 (modem, 它 包 括 调 制 和 解 调 两 个 功能 )。 
调制 解 调 器 以 串口 〈 serial ) 形式 工作 ， 因 为 字 节 中 的 单个 比特 是 一 个 接 一 个 传输 的 ， 而 
不 是 一 拥 而 上 (打印 机 一 般 通 过 并 行 接口 与 计算 机 相连 ， 整 个 字 节 由 8 根 线 并 行 传输 )。 


早期 调制 解 调 器 采用 了 频 移 键 控 ( frequency-shift keying, FSK ) 技术 。 假设 调制 解 调 
器 的 处 理 速 度 为 300 bps， 而 且 二 进 制 数 0 被 调制 到 1070 Hz, 而 1 被 调制 到 1270 Hz。 每 
个 字 节 被 夹 在 一 个 起 始 位 和 一 个 停止 位 中 间 , 所 以 每 个 字 节 其 实 占据 了 10 位 空间 。 在 300 
bps 的 传输 速率 下 ， 每 秒 传输 的 字 节 数 为 30 个 。 现 在 许多 采用 先进 技术 的 新 一 代 调 制 解 
调 器 速度 超过 了 它 的 100 倍 。 


早期 家 用 计算 机 的 狂热 爱好 者 可 以 使 用 计算 机 和 调制 解 调 器 建立 电子 公告 牌 系统 
( Bulletin Board System，BBS ), 其 他 计算 机 可 以 接 入 到 这 个 系统 中 并 下 载 (download ) 文 
件 ， 这 意味 着 文件 从 远程 计算 机 中 传输 到 了 自己 的 计算 机 。 这 些 概念 发 展 广泛 ， 甚 至 于 
扩展 到 了 大 型 信息 服务 领域 中 ， 例 如 线 上 资料 库 服 务 (CompuServe )。 在 大 多 数 环境 下 ， 
通信 中 采用 的 一 般 都 是 ASCII 码 。 


Internet 与 这 些 早期 的 发 明 有 本 质 上 的 差别 ， 因 为 它 是 一 种 非 中 心 化 的 系统 。Internet 
从 本 质 上 来 讲 是 一 组 协议 的 集合 ， 这 些 协 议 是 计算 机 之 间 相 互通 信 的 保证 。 众 多 的 协议 
中 ， 最 重要 的 当 属 TCP/IP 协议 ， 它 包括 了 传输 控制 协议 〈 Transmission Control Protocol， 
TCP ) 和 网 际 协 议 ( Internet Protocol, IP )。 这 种 协议 使 得 传输 过 程 变 得 规则 化 , 不 再 是 简 
单 地 通过 线路 传输 ASCII 码 字 符 , 而 由 基于 TCP/IP 协议 的 传输 系统 把 大 的 数据 块 分 割 成 
小 的 包 (packets )， 之 后 在 传输 线路 上 ( 通常 是 在 电话 线 上 ) 独立 发 送 ， 最 后 在 传输 线路 
的 另 一 端 将 数据 重新 组 装 起 来 。 


Internet 中 最 流行 的 是 万 维 网 ( World Wide Web )， 而 这 一 部 分 与 图 形 联 系 最 紧密 。 万 
维 网 采用 了 HTTP 协议 来 支持 其 工作 ，HTTP ( Hypertext Transfer Protocol ) 即 超 文本 传输 
协议 。 几 乎 所 有 在 Web 页 面 上 看 到 的 数据 都 遵循 一 定格 式 ， 那 就 是 HTML ( Hypertext 
Markup Language )， 即 超 文本 标记 语言 。 其 中 超 文 本 (hypertext ) 这 个 单词 用 来 描述 相关 
链接 信息 , 非常 类 似 于 万 :布什 预言 的 麦克 斯 储存 器 。 HTML 文件 可 以 包含 指向 其 他 Web 
页 面 的 链接 ， 这 样 可 以 轻松 访问 其 他 页 面 。 


bh. 418 


25 图 形 化 革命 


i 


HTML 与 本 章 前 面 讨论 过 的 富 文本 格式 (RIF ) 很 相似 ,它们 都 含有 带 有 格式 信息 的 
ASCII 码 文 本 。HTML 也 可 包含 多 种 图 片 格式 ， 例 如 : GIF 文件 、PNG (portable network 
graphics， 便 携 式 网 络 图 像 格 式 ) 文件 ， 以 及 下 下 (JPEG 文件 交换 格式 ) 等 。 大 部 分 万 
维 网 浏览 器 都 支持 浏览 HTML 文件 , 这 是 文本 格式 的 优势 所 在 。 易 检索 性 也 是 HTML 被 
定义 成 文本 文件 的 另 一 个 优点 。 虽 然 名 字 可 能 有 些 让 人 迷惑 ， 但 HTML 与 我 们 在 第 19 章 
和 第 24 章 讲 到 的 语言 不 同 ， 它 并 不 是 真正 的 程序 设计 语言 。Web 浏览 器 首先 读 取 HTML 
文件 ， 根 据 读 取 到 的 内 容 显 示 文 本 和 图 形 并 编排 它们 的 格式 。 


当 我 们 浏览 某 些 Web 页 面 并 进行 一 些 操作 时 ， 有 一 些 特殊 程序 需要 并 发 执行 ， 程 序 
中 的 代码 可 以 运行 在 服务 器 端 ( Server， 用 来 存储 原始 Web 页 面 的 计算 机 ) 或 客户 端 
( Client )， 我 们 自己 的 计算 机 就 是 客户 端 。 服 务 器 端 责任 重大 ， 通 常 要 完成 一 些 重 要 的 处 
理工 作 〈 例 如 解释 客户 端 填写 的 在 线 表格 )， 服 务 器 端的 工作 可 以 通过 公共 网 关 接 口 
(Common Gateway Interface，CGI ) 脚本 来 处 理 。 而 对 于 客户 端 ，HTML 文件 可 以 包含 简 
单 的 程序 设计 语言 , 例如 著名 的 JavaScript。Web 浏览 器 可 以 对 Java Script 语句 进行 解释 ，. 
就 像 解 释 HTML 文本 一 样 。 

为 什么 Web 站 点 不 为 我 们 的 计算 机 提供 一 个 可 执行 程序 ， 如 果 这 样 的 话 问题 一 下 子 
就 解决 了 。 要 回答 这 个 问题 ， 我 们 首先 要 明确 : 我 们 的 计算 机 是 什么 样 的 ? 如 果 使 用 的 
是 Macintosh 机 ,那么 这 个 可 执行 程序 需要 包含 Power PC 机 器 码 , 而 且 需 要 引用 Mac OS 
中 的 API 函数 ;如 果 是 一 台 PC 兼容 机 ,那么 这 个 可 执行 程序 需要 包含 Intel Pentium 机 器 
码 ， 而 且 需 要 使 用 Windows API 函数 。 但 计算 机 及 图 形 操作 系统 的 种 类 繁杂 ， 还 有 许多 
其 他 类 型 的 计算 机 和 图 形 操作 系统 。 进 一 步 来 说 ,我 们 也 不 想 毫 无 目的 地 下 载 可 执行 文 
件 ， 它们 很 可 能 来 自 于 非 信 任 站 点 而 且 会 带 有 恶意 行为 。 


上 述 问 题 的 答案 就 在 Sun 公司 开发 的 Java 语言 中 ( 请 缴 与 JavaSceript 混淆 )。Java 是 
一 款 成 熟 的 面向 对 象 程 序 设计 语言 ， 和 C+ 有 些 类 似 。 前 面 章 节 中 我 们 讨论 过 编译 语言 
(compiled languages， 可 产生 包含 机 器 码 的 可 执行 文件 的 语言 ) 和 解释 语言 ( 不 可 产生 可 
执行 文件 的 语言 ) 之 间 的 区 别 ，Java 是 一 种 介 于 两 者 之 间 的 语言 。 它 需要 经 过 编译 ， 但 
编译 的 结果 不 是 机 器 码 ， 而 是 Java 字 节 码 ( Java byte codes )。Java 字 节 但 与 机 器 人 码 在 结 
构 上 很 相似 ,但 Java 字 节 码 可 以 在 一 种 虚拟 的 计算 机 下 被 解释 , 即 Java 虚拟 机 ( Java Virtual 
Machine，JVM ) 上 。 被 编译 的 Java 程序 产生 Java 字 节 码 ， 之 后 计算 机 模拟 JVM 对 其 进 
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行 解释 。Java 程序 的 运行 可 以 不 受 限 于 机 器 与 图 形 操作 系统 的 类 型 ， 所 以 它 具 有 平台 无 
关 性 (platform- independent )。 


关于 如 何 利用 电流 在 线路 上 传输 信号 和 信息 ， 在 讲述 这 一 点 时 本 书 利 用 了 大 段 章节 ， 
但 其 实 有 一 种 更 加 行 之 有 效 的 方法 , 那 就 是 利用 光纤 种 由 玻璃 或 聚合 体制 造 的 光 导 
纤维 ， 通 过 从 不 同 角 度 对 光 进 行 反射 达到 光 传 输 效 果 。 光 信号 在 光纤 中 的 传输 速率 可 以 
达到 干 兆 赫兹 一 一 即 每 秒 十 亿 个 比特 。 


展望 未 来 ， 在 以 后 的 家 庭 和 办 公 室 中 ， 光 子 似 乎 要 替代 电子 承担 海量 信息 传输 的 重 
任 。 比 起 莫 尔 斯 码 中 的 一 “点 ”一 “ 划 ”， 比 起 为 了 与 一 街 之 隔 的 好 友 深 夜 交流 而 绞 尽 脑 
汁 想 出 的 闪光 灯 ， 光 子 的 速度 无 与 伦比 。 
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